Traffic data: Difference between revisions Discussion View history

(→‎What information is calculated: cross times - not transition times and cross speeds)
(→‎Traffic data: Major rewrite of intro and glossary.)
Line 2: Line 2:
This page is under construction.  This page has several facts {{red|DEAD WRONG}}.  Don't depend on it.
This page is under construction.  This page has several facts {{red|DEAD WRONG}}.  Don't depend on it.
=Traffic data=
=Traffic data=
The Waze map editor's motto is "usability, simplicity, retention". What we want to retain is the traffic data the Waze servers use for determining the best routes. When we understand what traffic data is stored and what happens to it when we change the map, we can understand the how to make the map work for all wazers. This page is for collecting all the publicly-available information about traffic data and how map editing affects it.
Along with every routable segment, Waze stores data about how long it takes to cross that segment and transition (straight, right, left, exit, keep) to every other segment that is junctioned to it. This information is used by the routing engine to figure out the fastest way to get to a destination. If a segment is deleted, then the information about the time it takes to cross it or enter it from another segment is also deleted,
==Glossary==
;Time slice :A specific day of week and portion of a day.  A time slice might cover an hour or half hour of the day, or it might cover a different length of time.
;Segment cross time:The time it takes a wazer to enter the the segment, cross it, and exit the segment i one of the possible exit directions. This time includes time, on average, spent "waiting for the light to change", "waiting to make a turn", or "waiting at the 4-way stop". For a 2-way segment connected to a 4-way intersection at each end, there are 4 segment cross times in the A->B direction (straight, left, right, and u-turn) and 4 more in the B->A direction. For segments marked as an HOV/Express segment (a segment which has an HOV or express lane on the right or left), there is an additional full set of cross times associated with the Express/HOV lane.


;Traversal Time :Some type of average (details not provided by the waze team) of the Segment cross times in the A->B or B->A direction.
This article explains what traffic data is stored and what happens to it when we change the map.  


==What information is stored==
==What traffic data is stored==
* Forward (A to B) and Reverse (B to A) segment cross times, for each possible exit from the segment, and for the HOV/Express lane if there is one.
*Waze stores Forward (A to B) and Reverse (B to A) '''segment cross times''' for each '''time slice''', for each possible exit from the segment. So if segment 100 is junctioned to segments 201 and 202 at its B junction node, there will be 2 cross times the A->B direction - for 100->201, 100->202.
* We do not know exactly how these numbers are calculated, what happens when wazers leave a segment before they get to the end, turn off their phone, or lose cell service. We don't know whether waze stores a lot of historical times or just keeps some kind ofrunning average, and whether it keeps data for more times of day then the 48 half-hour periods it shares with us through LIveMap.
*If the segment has a [[Carpool,_HOV,_Transit_lanes#Enter.2Fexit_anywhere_HOT.2FExpress_lanes|restricted lane]] (Bus, Express, HOV, etc) , the same type of information is stored for that "extra" lane. So if segment 100 also has a left HOV lane, then there will be 2 more cross times in the same direction - for 100HOV -> 201, 100HOV->202.
==Where does this information come from==
* When a new segment is created, initial segment cross times are created based on a default average speed for the road type and a transition time to each segment it is junctioned to. These values will be updated as soon as waze decides traffic has used the segment.
* Segment Cross Times are frequently updated by analyzing the traffic that has travelled on each segment at each time slice of the week, and that real-life segment cross times are averaged to come up with the stored values. There are a lot of details we do not know about how traffic data is analyzed, and how the traffic calculations take into account loss of cell service, wazers stopping on the side of the road or entering or leaving a segment in the middle. LiveMap shows us 48 times per day (every hour and half hour), and we don't know whether that has anything to do with the number of time slices Waze uses in its calculations.


== What information is calculated ==
==Glossary==
* Segment cross speed - calculated from segment cross time divided by length.
===Stored Traffic Data===
;Time slice :A specific day of week and portion of a day.  A time slice might cover an hour or half hour of the day, or it might cover a different length of time.
;Segment cross time :The time it takes a wazer to enter the the segment, cross it, and exit the segment i one of the possible exit directions. This time includes time, on average, spent "waiting for the light to change", "waiting to make a turn", or "waiting at the 4-way stop". For a 2-way segment connected to a 4-way intersection at each end, there are 4 segment cross times in the A->B direction (straight, left, right, and u-turn) and 4 more in the B->A direction. For segments marked as an HOV/Express segment (a segment which has an HOV or express lane on the right or left), there is an additional full set of cross times associated with the Express/HOV lane.
===Calculated Traffic Data===
;Segment cross speed :segment cross time divided by length.
;Traversal Time :A calculated "base" time to cross a segment in the A->B or B->A direction, not including transition times to cross from one segment to one of the other segments it is junctioned to. Might be used to calculate new segment cross times when an existing segment is cut into two new segments.
;Transition Time :A calculated "wait" time to transition from one segment to another, not counting the Traversal time. Might be used to calculate new segment cross times when an existing segment is cut into two new segments.


==What information we can see==
==What information we can see==
Scripts like route speeds can get the time to cross from one segment to the next for every half hour for every day of the week, along any of the routes the routing server gave it.
Scripts like route speeds can retrieve segment cross times for an hour or half hour, any day of the week, along any of the routes the routing server gave it. These scripts can calcuate speeds based on these cross times.


==When is traffic data lost?==
==When is traffic data lost?==
* When a segment is deleted, all traffic data involving that segment is lost.
* When a segment is deleted, all traffic data involving that segment is lost.
* When a segment is permanently disconnected from another segment at a junction, all segment cross times involving transitions between those two segments will be lost.
* When a segment is permanently disconnected from another segment at a junction, all segment cross times involving transitions between those two segments will eventually be lost.
* If no traffic is assigned to a direction on a segment then the old traffic data for that direction will be retained for a week or two. After that, it will be lost.
* If no traffic is assigned to a segment or a direction on a segment then the old traffic data for that direction will be retained for a week or two. After that, it will be lost.


==What happens to traffic data when you make changes to the roads==
==What happens to traffic data when you make changes to the roads==
* When you delete a segment (let's call it segment 100)
* When you delete a segment (let's call it segment 100)
**its cross times  to other segments are deleted.
**its cross times  to other segments are deleted.
**all cross times from other segments to that segment are lost; waze does not remember "turning left from segment 101 is a long wait" it remembers "the cross time from segment 101 to segment 100 is 4 minutes at 5:30 PM on Monday". If you delete segment 100, Waze can no longer use that information.
**all cross times from other segments to that segment are lost; waze does not remember "turning left from segment 101 is a long wait" it remembers "the cross time from segment 101 to segment 100 is 4 minutes at 5:30 PM on Monday". If you delete segment 100, Waze no longer has any use for that information.
** When you delete a segment and draw a new one, waze has to start from scratch collecting data on segment cross times.
** When you delete a segment and replace it with a newly-drawn segment, waze has to start from scratch collecting data on segment cross times.
* When you shift the position of a junction without disconnecting anything, changing the lengths of several segments
* When you shift the position of a junction without disconnecting anything, changing the lengths of several segments
** The cross times are not changed
** {{red|The cross times are not changed '''OR''' The cross times are changed in a proportional way to account for the fact that the junction has moved}}
** Cross speed calculations will change because the lengths of the segments has changed
** Over time, the stored traffic data will change to bring segment cross times back into line with reality.
** Over time, the stored traffic data will change to bring segment cross times back into line with reality.
* When you cut a segment (let's call it segment 100) into 2 shorter segments without changing anything else at the 2 original junctions
* When you cut a segment (let's call it segment 100) into 2 shorter segments without changing anything else at the 2 original junctions
** Two new segments are created with brand-new segment IDs (let's call them 201 and 202)
** Two new segments are created with brand-new segment IDs (let's call them 201 and 202)
** The segment and the segment ID (100) from the segment you cut is gone.
** The segment and the segment ID (100) from the segment you cut is gone.
** The times of the original segment is used to calculate new cross times for the new segments, using a calculated traversal time and cross speed to figure new cross times for both of the new segments.
** The segment cross times of the original segment is used to calculate new cross times for the new segments, using a calculated traversal time and cross speed to figure new cross times for both of the new segments.
** A junction node is created where the two new segments are joined.
** A junction node is created where the two new segments are joined.
** Cross time between the two new segments.Transition times between the two new segments (201 and 202) are created; some default value is used.
** Cross time between the two new segments.Transition times between the two new segments (201 and 202) are created; some default value is used.

Revision as of 17:40, 23 January 2018

You can bring up comments or questions about this in
 Traffic Data forum topic.

This page is under construction. This page has several facts DEAD WRONG. Don't depend on it.

Traffic data

Along with every routable segment, Waze stores data about how long it takes to cross that segment and transition (straight, right, left, exit, keep) to every other segment that is junctioned to it. This information is used by the routing engine to figure out the fastest way to get to a destination. If a segment is deleted, then the information about the time it takes to cross it or enter it from another segment is also deleted,

This article explains what traffic data is stored and what happens to it when we change the map.

What traffic data is stored

  • Waze stores Forward (A to B) and Reverse (B to A) segment cross times for each time slice, for each possible exit from the segment. So if segment 100 is junctioned to segments 201 and 202 at its B junction node, there will be 2 cross times the A->B direction - for 100->201, 100->202.
  • If the segment has a restricted lane (Bus, Express, HOV, etc) , the same type of information is stored for that "extra" lane. So if segment 100 also has a left HOV lane, then there will be 2 more cross times in the same direction - for 100HOV -> 201, 100HOV->202.

Where does this information come from

  • When a new segment is created, initial segment cross times are created based on a default average speed for the road type and a transition time to each segment it is junctioned to. These values will be updated as soon as waze decides traffic has used the segment.
  • Segment Cross Times are frequently updated by analyzing the traffic that has travelled on each segment at each time slice of the week, and that real-life segment cross times are averaged to come up with the stored values. There are a lot of details we do not know about how traffic data is analyzed, and how the traffic calculations take into account loss of cell service, wazers stopping on the side of the road or entering or leaving a segment in the middle. LiveMap shows us 48 times per day (every hour and half hour), and we don't know whether that has anything to do with the number of time slices Waze uses in its calculations.

Glossary

Stored Traffic Data

Time slice
A specific day of week and portion of a day. A time slice might cover an hour or half hour of the day, or it might cover a different length of time.
Segment cross time
The time it takes a wazer to enter the the segment, cross it, and exit the segment i one of the possible exit directions. This time includes time, on average, spent "waiting for the light to change", "waiting to make a turn", or "waiting at the 4-way stop". For a 2-way segment connected to a 4-way intersection at each end, there are 4 segment cross times in the A->B direction (straight, left, right, and u-turn) and 4 more in the B->A direction. For segments marked as an HOV/Express segment (a segment which has an HOV or express lane on the right or left), there is an additional full set of cross times associated with the Express/HOV lane.

Calculated Traffic Data

Segment cross speed
segment cross time divided by length.
Traversal Time
A calculated "base" time to cross a segment in the A->B or B->A direction, not including transition times to cross from one segment to one of the other segments it is junctioned to. Might be used to calculate new segment cross times when an existing segment is cut into two new segments.
Transition Time
A calculated "wait" time to transition from one segment to another, not counting the Traversal time. Might be used to calculate new segment cross times when an existing segment is cut into two new segments.

What information we can see

Scripts like route speeds can retrieve segment cross times for an hour or half hour, any day of the week, along any of the routes the routing server gave it. These scripts can calcuate speeds based on these cross times.

When is traffic data lost?

  • When a segment is deleted, all traffic data involving that segment is lost.
  • When a segment is permanently disconnected from another segment at a junction, all segment cross times involving transitions between those two segments will eventually be lost.
  • If no traffic is assigned to a segment or a direction on a segment then the old traffic data for that direction will be retained for a week or two. After that, it will be lost.

What happens to traffic data when you make changes to the roads

  • When you delete a segment (let's call it segment 100)
    • its cross times to other segments are deleted.
    • all cross times from other segments to that segment are lost; waze does not remember "turning left from segment 101 is a long wait" it remembers "the cross time from segment 101 to segment 100 is 4 minutes at 5:30 PM on Monday". If you delete segment 100, Waze no longer has any use for that information.
    • When you delete a segment and replace it with a newly-drawn segment, waze has to start from scratch collecting data on segment cross times.
  • When you shift the position of a junction without disconnecting anything, changing the lengths of several segments
    • The cross times are not changed OR The cross times are changed in a proportional way to account for the fact that the junction has moved
    • Over time, the stored traffic data will change to bring segment cross times back into line with reality.
  • When you cut a segment (let's call it segment 100) into 2 shorter segments without changing anything else at the 2 original junctions
    • Two new segments are created with brand-new segment IDs (let's call them 201 and 202)
    • The segment and the segment ID (100) from the segment you cut is gone.
    • The segment cross times of the original segment is used to calculate new cross times for the new segments, using a calculated traversal time and cross speed to figure new cross times for both of the new segments.
    • A junction node is created where the two new segments are joined.
    • Cross time between the two new segments.Transition times between the two new segments (201 and 202) are created; some default value is used.
    • Over time, the stored traffic data will change to adjust the new transition times in line with reality.
  • When you disconnect all segments from a junction node and save:
    • The junction node is deleted.
    • The transition times passing through that junction node are lost.
  • When you move segments from one junction node to another junction node
    • All transition times which passed through the first junction node are lost, because they were associated with the two connected segment IDs.
    • New transition times connecting the same segments through the new junction node are created.
    • If you begin with two segments, 101 and 102 disconnected them, and reconnected them through a new junction node, the transition times between 101 and 102 will be lost. They will be replaced by new default values.
    • Over time, transition times between the two segments will be adjusted to reflect the new traffic data.
  • Traffic data corresponding to a restricted (red) transition arrow between segment 200 and 201 will still be collected as long as traffic can be assigned to segments 200 and 201 (see below)
  • Traffic data corresponding to the "wrong direction" on a one-way segment will not be collected if the traffic data is assigned to other nearby segments. If no traffic is asigned to a segment direction, the old traffic data will be retained for a week or two.
  • If a 2-way segment is improperly divided by drawing a new one-way segment parallel to the old segment, and the old segment is made one-way, then the stored "wrong way" traffic data on the old segment will be retained for a period of a week or two. New traffic data in that direction will be collected on the new one-way segment.

Unanswered Questions

What happens when

  • Drag one junction node with two segments on top of another junction node with another 2 segments. Are the s1->s2 and s3->s4 transition times retained at the new junction node?
  • Create 1 segment from 2 by deleting the junction joining them.
    • Cross speed?
    • Transition times at the nodes on either end of the new segment?
    • Transition time between the 2 segments that have been joined to create the new segment?
  • disconnect a segment from a junction
    • and reconnect it before saving.
    • and save it disconnected, but reconnect it and save again before the next tile update
    • and save it disconnected through the next tile update, then reconnect directly after tile update.
    • for a few days, weeks, or months -- as a way to close a road during construction.
      • and then reconnect it to the same junction (nothing else having changed at that junction in the meantime)
  • Connect a segment to a junction
    • a former "dead-end" node of an existing segment
  • convert a bow tie junction to a "H" junction by the following method
    1. disconnect segment 1 from the bow tie junction
    2. connect segment 1 to the cross segment to create a new junction
    3. disconnect segment 2 from the bow tie junction
    4. connect segment 2 to the new junction.
  • convert a bow tie junction to a "H" junction by the following method
    1. bridge segment 1 to segment 2
    2. move the joined segment to the new junction location on the cross segment
    3. reduce the elevation to ground and use the "junction" icon to create the new junction.