cache-valley — Source Data Validation Report

This report was generated by the Canonical GTFS Schedule validator, version 7.1.0 at 2026-06-11T17:37:49Z,
for the dataset file:///shared/cache-valley_c05296e7.zip. No country code was provided.

Use this report alongside our documentation.

A new version of the Canonical GTFS Schedule validator is available! Please update to get the latest/best validation results.

Summary

Agencies included


  • CVTD Cache Valley Transit District

Feed Info


Publisher Name:
GMV Syncromatics
Feed Email:
support@gmvsync.com
Feed Language:
English
Feed Start Date:
2026-06-09
Feed End Date:
N/A

Files included


  1. agency.txt
  2. calendar.txt
  3. calendar_attributes.txt
  4. directions.txt
  5. feed_info.txt
  6. realtime_routes.txt
  7. routes.txt
  8. shapes.txt
  9. stop_times.txt
  10. stops.txt
  11. trips.txt

Counts


  • Agencies: 1
  • Blocks: 33
  • Routes: 15
  • Shapes: 26
  • Stops: 333
  • Trips: 651

Specification Compliance report

287 notices reported (0 errors, 284 warnings, 3 infos)

Notice Code Severity Total
equal_shape_distance_same_coordinates WARNING 32

equal_shape_distance_same_coordinates

Two consecutive points have equal shape_dist_traveled and the same lat/lon coordinates in shapes.txt.

When sorted by shape.shape_pt_sequence, the values for shape_dist_traveled must increase along a shape. Two consecutive points with equal values for shape_dist_traveled and the same coordinates indicate a duplicative shape point.

You can see more about this notice here.

shapeId (?) The id of the faulty shape. csvRowNumber (?) The row number from `shapes.txt`. shapeDistTraveled (?) Actual distance traveled along the shape from the first shape point to the faulty record. shapePtSequence (?) The faulty record's `shapes.shape_pt_sequence`. prevCsvRowNumber (?) The row number from `shapes.txt` of the previous shape point. prevShapeDistTraveled (?) Actual distance traveled along the shape from the first shape point to the previous shape point. prevShapePtSequence (?) The previous record's `shapes.shape_pt_sequence`.
"28231" 3425 8968.873728015351 68 3424 8968.873728015351 67
"28231" 3426 8968.873728015351 69 3425 8968.873728015351 68
"28231" 3435 9183.196002048404 78 3434 9183.196002048404 77
"28231" 3442 9208.435655528547 85 3441 9208.435655528547 84
"28231" 3449 9335.872670411474 92 3448 9335.872670411474 91
"28231" 3450 9335.872670411474 93 3449 9335.872670411474 92
"28231" 3456 9498.11634023807 99 3455 9498.11634023807 98
"28231" 3472 9620.71853496036 115 3471 9620.71853496036 114
"28231" 3490 10372.01783752522 133 3489 10372.01783752522 132
"28231" 3491 10372.01783752522 134 3490 10372.01783752522 133
"28231" 3502 10574.707619724704 145 3501 10574.707619724704 144
"28232" 3627 7247.321636193279 54 3626 7247.321636193279 53
"28232" 3628 7247.321636193279 55 3627 7247.321636193279 54
"28232" 3630 7257.33663494589 57 3629 7257.33663494589 56
"28232" 3633 7315.681960593747 60 3632 7315.681960593747 59
"28232" 3647 7518.617021071736 74 3646 7518.617021071736 73
"28232" 3648 7518.617021071736 75 3647 7518.617021071736 74
"28232" 3651 7534.660306006114 78 3650 7534.660306006114 77
"28232" 3655 7555.983721746091 82 3654 7555.983721746091 81
"28232" 3656 7555.983721746091 83 3655 7555.983721746091 82
"28232" 3664 7699.344187646963 91 3663 7699.344187646963 90
"28232" 3665 7699.344187646963 92 3664 7699.344187646963 91
"28232" 3682 8372.070076715463 109 3681 8372.070076715463 108
"28232" 3683 8372.070076715463 110 3682 8372.070076715463 109
"28232" 3689 8482.484749608913 116 3688 8482.484749608913 115
"28232" 3699 8564.334041867334 126 3698 8564.334041867334 125
"28232" 3710 8854.985472712022 137 3709 8854.985472712022 136
"28232" 3717 8885.962445546284 144 3716 8885.962445546284 143
"28232" 3727 9124.322538668739 154 3726 9124.322538668739 153
"28232" 3728 9124.322538668739 155 3727 9124.322538668739 154
"28232" 3729 9124.322538668739 156 3728 9124.322538668739 155
"28232" 3732 9223.365081232323 159 3731 9223.365081232323 158
fast_travel_between_consecutive_stops WARNING 2

fast_travel_between_consecutive_stops

A transit vehicle moves too fast between two consecutive stops.

The speed threshold depends on route type:

Route type Description Threshold, km/h
0 Light rail 100
1 Subway 150
2 Rail 500
3 Bus 150
4 Ferry 80
5 Cable tram 30
6 Aerial lift 50
7 Funicular 50
11 Trolleybus 150
12 Monorail 150
- Unknown 200

You can see more about this notice here.

tripCsvRowNumber (?) The row number of the problematic trip. tripId (?) `trip_id` of the problematic trip. routeId (?) `route_id` of the problematic trip. speedKph (?) Travel speed (km/h). distanceKm (?) Distance between stops (km). csvRowNumber1 (?) The row number of the first stop time. stopSequence1 (?) `stop_sequence` of the first stop. stopId1 (?) `stop_id` of the first stop. stopName1 (?) `stop_name` of the first stop. departureTime1 (?) `departure_time` of the first stop. csvRowNumber2 (?) The row number of the second stop time. stopSequence2 (?) `stop_sequence` of the second stop. stopId2 (?) `stop_id` of the second stop. stopName2 (?) `stop_name` of the second stop. arrivalTime2 (?) `arrival_time` of the second stop.
498 "B1_0921" "5723" 163.99937202634348 0.6833307167764312 11429 22 "7606926" "150 East 442 North" "09:53:00" 11430 23 "7579425" "750 North Main St" "09:53:15"
600 "G1S_1550" "5722" 151.1243615034729 0.6296848395978037 14642 22 "7547678" "355 North Main" "16:27:00" 14643 23 "7547679" "55 North Main" "16:27:15"
leading_or_trailing_whitespaces WARNING 3

leading_or_trailing_whitespaces

The value in CSV file has leading or trailing whitespaces.

This notice is emitted for values protected with double quotes since whitespaces for non-protected values are trimmed automatically by CSV parser.

The validator strips whitespaces from protected values. We do not see any use case when such a whitespace may be needed. On the other hand, some real-world feeds use trailing whitespaces for some values and omit them for the others. This is causing the largest problem when a primary key and a foreign key differ just by a whitespace: it is clear that they are intended to be the same, that is why we always strip whitespaces.

You can see more about this notice here.

filename (?) The name of the faulty file. csvRowNumber (?) The row of the faulty record. fieldName (?) Faulty record's field name. fieldValue (?) Faulty value.
"stops.txt" 180 "stop_name" "941 North 600 West "
"stops.txt" 181 "stop_name" "675 North 600 West "
"routes.txt" 4 "route_desc" "Island, Wilson, Tabernacle "
missing_feed_info_date WARNING 1

missing_feed_info_date

One of feed_start_date or feed_end_date is specified, but not both.

Even though feed_info.start_date and feed_info.end_date are optional, if one field is provided the second one should also be provided.

You can see more about this notice here.

csvRowNumber (?) The row number of the faulty record. fieldName (?) Either `feed_end_date` or `feed_start_date`.
2 "feed_end_date"
missing_recommended_field WARNING 1

missing_recommended_field

A recommended field is missing.

The given field has no value in some input row, even though values are recommended.

You can see more about this notice here.

filename (?) The name of the faulty file. csvRowNumber (?) The row of the faulty record. fieldName (?) The name of the missing field.
"feed_info.txt" 2 "feed_end_date"
mixed_case_recommended_field WARNING 162

mixed_case_recommended_field

This field has customer-facing text and should use Mixed Case (should contain upper and lower case letters).

This field contains customer-facing text and should use Mixed Case (upper and lower case letters) to ensure good readability when displayed to riders. Avoid the use of abbreviations throughout the feed (e.g. St. for Street) unless a location is called by its abbreviated name (e.g. “JFK Airport”). Abbreviations may be problematic for accessibility by screen reader software and voice user interfaces.

Good examples:
Field Text Dataset
"Schwerin, Hauptbahnhof" Verkehrsverbund Berlin-Brandenburg
"Red Hook/Atlantic Basin" NYC Ferry
"Campo Grande Norte" Carris
Bad examples:
Field Text
"GALLERIA MALL"
"3427 GG 17"
"21 Clark Rd Est"

You can see more about this notice here.

Only the first 50 of 162 affected records are displayed below.

filename (?) Name of the faulty file. fieldName (?) Name of the faulty field. fieldValue (?) Faulty value. csvRowNumber (?) The row number of the faulty record.
"routes.txt" "route_short_name" "16 PM" 10
"routes.txt" "route_short_name" "16 AM" 13
"trips.txt" "trip_headsign" "BLUE LOOP" 493
"trips.txt" "trip_headsign" "BLUE LOOP" 494
"trips.txt" "trip_headsign" "BLUE LOOP" 495
"trips.txt" "trip_headsign" "BLUE LOOP" 496
"trips.txt" "trip_headsign" "BLUE LOOP" 497
"trips.txt" "trip_headsign" "BLUE LOOP" 498
"trips.txt" "trip_headsign" "BLUE LOOP" 499
"trips.txt" "trip_headsign" "BLUE LOOP" 500
"trips.txt" "trip_headsign" "BLUE LOOP" 501
"trips.txt" "trip_headsign" "BLUE LOOP" 502
"trips.txt" "trip_headsign" "BLUE LOOP" 503
"trips.txt" "trip_headsign" "BLUE LOOP" 504
"trips.txt" "trip_headsign" "BLUE LOOP" 505
"trips.txt" "trip_headsign" "BLUE LOOP" 506
"trips.txt" "trip_headsign" "BLUE LOOP" 507
"trips.txt" "trip_headsign" "BLUE LOOP" 508
"trips.txt" "trip_headsign" "BLUE LOOP" 509
"trips.txt" "trip_headsign" "BLUE LOOP" 510
"trips.txt" "trip_headsign" "BLUE LOOP" 511
"trips.txt" "trip_headsign" "BLUE LOOP" 512
"trips.txt" "trip_headsign" "BLUE LOOP" 513
"trips.txt" "trip_headsign" "BLUE LOOP" 514
"trips.txt" "trip_headsign" "BLUE LOOP" 515
"trips.txt" "trip_headsign" "BLUE LOOP" 516
"trips.txt" "trip_headsign" "BLUE LOOP" 517
"trips.txt" "trip_headsign" "BLUE LOOP" 518
"trips.txt" "trip_headsign" "BLUE LOOP" 519
"trips.txt" "trip_headsign" "BLUE LOOP" 520
"trips.txt" "trip_headsign" "BLUE LOOP" 521
"trips.txt" "trip_headsign" "BLUE LOOP" 522
"trips.txt" "trip_headsign" "BLUE LOOP" 523
"trips.txt" "trip_headsign" "BLUE LOOP" 524
"trips.txt" "trip_headsign" "BLUE LOOP" 525
"trips.txt" "trip_headsign" "BLUE LOOP" 526
"trips.txt" "trip_headsign" "BLUE LOOP" 527
"trips.txt" "trip_headsign" "BLUE LOOP" 528
"trips.txt" "trip_headsign" "BLUE LOOP" 529
"trips.txt" "trip_headsign" "BLUE LOOP" 530
"trips.txt" "trip_headsign" "BLUE LOOP" 531
"trips.txt" "trip_headsign" "BLUE LOOP" 532
"trips.txt" "trip_headsign" "BLUE LOOP" 533
"trips.txt" "trip_headsign" "BLUE LOOP" 534
"trips.txt" "trip_headsign" "BLUE LOOP" 535
"trips.txt" "trip_headsign" "BLUE LOOP" 536
"trips.txt" "trip_headsign" "BLUE LOOP" 537
"trips.txt" "trip_headsign" "BLUE LOOP" 538
"trips.txt" "trip_headsign" "BLUE LOOP" 539
"trips.txt" "trip_headsign" "BLUE LOOP" 540
same_name_and_description_for_stop WARNING 1

same_name_and_description_for_stop

Same name and description for stop.

The GTFS spec defines stops.txt stop_description as:

Description of the location that provides useful, quality information. Do not simply duplicate the name of the location.

You can see more about this notice here.

csvRowNumber (?) The row number of the faulty record. stopId (?) The id of the faulty record. stopDesc (?) The faulty record's `stop_desc`.
4 "11053147" "649 North 200 West"
stop_too_far_from_shape_using_user_distance WARNING 10

stop_too_far_from_shape_using_user_distance

Stop time too far from shape.

A stop time entry that is a large distance away from the location of the shape in shapes.txt as defined by shape_dist_traveled values.

You can see more about this notice here.

tripCsvRowNumber (?) The row number of the faulty record from `trips.txt`. shapeId (?) The id of the shape that is referred to. tripId (?) The id of the trip that is referred to. stopTimeCsvRowNumber (?) The row number of the faulty record from `stop_times.txt`. stopId (?) The id of the stop that is referred to. stopName (?) The name of the stop that is referred to. match (?) Latitude and longitude pair of the location. geoDistanceToShape (?) Distance from stop to shape.
328 "19760" "5S_1030" 8255 "7581240" "380 East 2600 North, N Logan" [41.77993875843615,-111.8253206721471] 115.91473144434057
328 "19760" "5S_1030" 8256 "7581241" "2489 North 400 East, N Logan" [41.77847870978566,-111.82293585082292] 116.3472184665688
328 "19760" "5S_1030" 8257 "7507813" "2371 North 400 East, N Logan" [41.77652031397902,-111.82307383863827] 116.33250754051102
328 "19760" "5S_1030" 8259 "7581274" "2169 North 200 East, N Logan" [41.772405556238226,-111.82847134650994] 107.47524985097866
328 "19760" "5S_1030" 8260 "7581275" "1765 North 200 East, N Logan" [41.76453131334672,-111.82880800011056] 116.33668467306195
328 "19760" "5S_1030" 8261 "7581276" "1581 North 200 East" [41.761868346509196,-111.82891614628956] 116.22830581348605
328 "19760" "5S_1030" 8262 "7569966" "1365 North 200 East" [41.75723672304867,-111.82915950688523] 116.31654606725891
328 "19760" "5S_1030" 8263 "7569971" "1201 North 200 East" [41.75385793691956,-111.82922671398357] 115.8323223916731
328 "19760" "5S_1030" 8264 "7569968" "979 North 200 East" [41.7506894265266,-111.8293637727002] 116.19611888314591
328 "19760" "5S_1030" 8266 "7504862" "150 East 500 North - Route 2" [41.74090649141658,-111.83198975679696] 113.91509201901908
stop_without_stop_time WARNING 20

stop_without_stop_time

A stop in stops.txt is not referenced by any stop_times.stop_id.

Such stops are not used by any trip and normally do not provide user value. This notice may indicate a typo in stop_times.txt.

You can see more about this notice here.

csvRowNumber (?) The row number of the faulty record. stopId (?) The id of the faulty stop. stopName (?) The name of the faulty stop.
60 "7547676" "453 West 100 North"
108 "7565651" "341 South 100 East"
109 "7565652" "640 South 100 East"
110 "7565653" "715 South Gateway Drive"
111 "7565654" "357 North Gateway Drive"
113 "7565656" "1305 South Talon Dr"
114 "7565657" "443 West 1700 South"
115 "7565659" "1771 Hyclone Dr"
116 "7565660" "1129 West 1800 South"
117 "7565661" "1776 South 1280 West"
118 "7565726" "1260 West 1610 South"
119 "7565727" "1776 South 1200 West"
120 "7565729" "1118 West Nibley Park Ave"
121 "7565730" "860 West Nibley Park Ave"
122 "7565731" "740 West 2600 South"
123 "7565732" "2639 South 600 West"
124 "7565733" "2775 South 600 West"
125 "7565734" "2963 South 600 West"
142 "7565918" "1559 South Talon Dr"
325 "9607861" "850 West 1600 South"
trip_distance_exceeds_shape_distance_below_threshold WARNING 52

trip_distance_exceeds_shape_distance_below_threshold

The distance between the last shape point and last stop point is greater than 0 but less than the 11.1m threshold.

You can see more about this notice here.

Only the first 50 of 52 affected records are displayed below.

tripId (?) The faulty record's trip id. shapeId (?) The faulty record's shape id. maxTripDistanceTraveled (?) The faulty record's trip max distance traveled. maxShapeDistanceTraveled (?) The faulty record's shape max distance traveled. geoDistanceToShape (?) The distance in meters between the shape and the stop.
"15_0500_O" "30724" 27509.557250492824 27509.55725049278 0.0
"15_0530_O" "30724" 27509.557250492824 27509.55725049278 0.0
"15_0600_O" "30724" 27509.557250492824 27509.55725049278 0.0
"15_0630_O" "30724" 27509.557250492824 27509.55725049278 0.0
"15_0700_O" "30724" 27509.557250492824 27509.55725049278 0.0
"15_0730_O" "30724" 27509.557250492824 27509.55725049278 0.0
"15_0800_O" "30724" 27509.557250492824 27509.55725049278 0.0
"15_0830_O" "30724" 27509.557250492824 27509.55725049278 0.0
"15_0900_O" "30724" 27509.557250492824 27509.55725049278 0.0
"15_0930_O" "30724" 27509.557250492824 27509.55725049278 0.0
"15_1000_O" "30724" 27509.557250492824 27509.55725049278 0.0
"15_1030_O" "30724" 27509.557250492824 27509.55725049278 0.0
"15_1100_O" "30724" 27509.557250492824 27509.55725049278 0.0
"15_1130_O" "30724" 27509.557250492824 27509.55725049278 0.0
"15_1200_O" "30724" 27509.557250492824 27509.55725049278 0.0
"15_1230_O" "30724" 27509.557250492824 27509.55725049278 0.0
"15_1300_O" "30724" 27509.557250492824 27509.55725049278 0.0
"15_1330_O" "30724" 27509.557250492824 27509.55725049278 0.0
"15_1400_O" "30724" 27509.557250492824 27509.55725049278 0.0
"15_1430_O" "30724" 27509.557250492824 27509.55725049278 0.0
"15_1500_O" "30724" 27509.557250492824 27509.55725049278 0.0
"15_1530_O" "30724" 27509.557250492824 27509.55725049278 0.0
"15_1600_O" "30724" 27509.557250492824 27509.55725049278 0.0
"15_1630_O" "30724" 27509.557250492824 27509.55725049278 0.0
"15_1700_O" "30724" 27509.557250492824 27509.55725049278 0.0
"15_1730_O" "30724" 27509.557250492824 27509.55725049278 0.0
"15_1800_O" "30724" 27509.557250492824 27509.55725049278 0.0
"15_1830_O" "30724" 27509.557250492824 27509.55725049278 0.0
"15_1900_O" "30724" 27509.557250492824 27509.55725049278 0.0
"15S_0930_O" "30724" 27509.557250492824 27509.55725049278 0.0
"15S_1100_O" "30724" 27509.557250492824 27509.55725049278 0.0
"15S_1230_O" "30724" 27509.557250492824 27509.55725049278 0.0
"15S_1400_O" "30724" 27509.557250492824 27509.55725049278 0.0
"15S_1530_O" "30724" 27509.557250492824 27509.55725049278 0.0
"15S_1700_O" "30724" 27509.557250492824 27509.55725049278 0.0
"6S_1012" "27006" 9608.697061559642 9608.683981024324 0.0
"6S_1100" "27006" 9608.697061559642 9608.683981024324 0.0
"6S_1200" "27006" 9608.697061559642 9608.683981024324 0.0
"6S_1300" "27006" 9608.697061559642 9608.683981024324 0.0
"6S_1400" "27006" 9608.697061559642 9608.683981024324 0.0
"6S_1500" "27006" 9608.697061559642 9608.683981024324 0.0
"6S_1600" "27006" 9608.697061559642 9608.683981024324 0.0
"6S_1700" "27006" 9608.697061559642 9608.683981024324 0.0
"6S_1800" "27006" 9608.697061559642 9608.683981024324 0.0
"7S_1030" "27001" 8508.423012522324 8508.298822717172 0.0
"7S_1130" "27001" 8508.423012522324 8508.298822717172 0.0
"7S_1230" "27001" 8508.423012522324 8508.298822717172 0.0
"7S_1330" "27001" 8508.423012522324 8508.298822717172 0.0
"7S_1430" "27001" 8508.423012522324 8508.298822717172 0.0
"7S_1530" "27001" 8508.423012522324 8508.298822717172 0.0
unknown_file INFO 3

unknown_file

A file is unknown.

You can see more about this notice here.

filename (?) The name of the unknown file.
"calendar_attributes.txt"
"realtime_routes.txt"
"directions.txt"