tank-transit — Source Data Validation Report

This report was generated by the Canonical GTFS Schedule validator, version 8.0.1 at 2026-06-27T05:17:14Z,
for the dataset file:///shared/tank-transit_8c297a89.zip. No country code was provided.

Use this report alongside our documentation.

Summary

Agencies included


  • Transit Authority of Northern Kentucky

Feed Info


Publisher Name:
Transit Authority of Northern Kentucky
Feed Email:
N/A
Feed Language:
English
Feed Start Date:
2026-06-02
Feed End Date:
2026-11-06

Files included


  1. agency.txt
  2. calendar.txt
  3. calendar_dates.txt
  4. fare_attributes.txt
  5. feed_info.txt
  6. frequencies.txt
  7. routes.txt
  8. shapes.txt
  9. stop_times.txt
  10. stops.txt
  11. transfers.txt
  12. trips.txt

Counts


  • Agencies: 1
  • Blocks: 231
  • Routes: 26
  • Shapes: 114
  • Stops: 809
  • Trips: 2021

Specification Compliance report

156 notices reported (0 errors, 152 warnings, 4 infos)

Notice Code Severity Total
fast_travel_between_consecutive_stops WARNING 106

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.

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

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.
174 "t541-b9E-sl1D" "1" 435.43655628030837 0.4838183958670093 31794 2756 "301451" "Dixie at Hilton" "14:30:56" 31795 2760 "301461" "Dixie at St Joseph" "14:31:00"
9 "t285-b25F-sl1B" "1" 435.43655628030837 0.4838183958670093 5749 2756 "301451" "Dixie at Hilton" "07:30:56" 5750 2760 "301461" "Dixie at St Joseph" "07:31:00"
146 "t285-b68-sl1D" "1" 435.43655628030837 0.4838183958670093 5749 2756 "301451" "Dixie at Hilton" "07:30:56" 5750 2760 "301461" "Dixie at St Joseph" "07:31:00"
76 "t285-b2C3-sl1C" "1" 435.43655628030837 0.4838183958670093 5749 2756 "301451" "Dixie at Hilton" "07:30:56" 5750 2760 "301461" "Dixie at St Joseph" "07:31:00"
77 "t2CB-b2C8-sl1C" "1" 435.43655628030837 0.4838183958670093 7550 2756 "301451" "Dixie at Hilton" "08:00:56" 7551 2760 "301461" "Dixie at St Joseph" "08:01:00"
10 "t2CB-b264-sl1B" "1" 435.43655628030837 0.4838183958670093 7550 2756 "301451" "Dixie at Hilton" "08:00:56" 7551 2760 "301461" "Dixie at St Joseph" "08:01:00"
149 "t2CB-b73-sl1D" "1" 435.43655628030837 0.4838183958670093 7550 2756 "301451" "Dixie at Hilton" "08:00:56" 7551 2760 "301461" "Dixie at St Joseph" "08:01:00"
125 "t77B-b2E1-sl1C" "1" 435.43655628030837 0.4838183958670093 53413 2756 "301451" "Dixie at Hilton" "20:00:56" 53414 2760 "301461" "Dixie at St Joseph" "20:01:00"
58 "t77B-b27D-sl1B" "1" 435.43655628030837 0.4838183958670093 53413 2756 "301451" "Dixie at Hilton" "20:00:56" 53414 2760 "301461" "Dixie at St Joseph" "20:01:00"
196 "t77B-b9D-sl1D" "1" 435.43655628030837 0.4838183958670093 53413 2756 "301451" "Dixie at Hilton" "20:00:56" 53414 2760 "301461" "Dixie at St Joseph" "20:01:00"
120 "t6D1-b2E6-sl1C" "1" 435.43655628030837 0.4838183958670093 47681 2756 "301451" "Dixie at Hilton" "18:30:56" 47682 2760 "301461" "Dixie at St Joseph" "18:31:00"
53 "t6D1-b282-sl1B" "1" 435.43655628030837 0.4838183958670093 47681 2756 "301451" "Dixie at Hilton" "18:30:56" 47682 2760 "301461" "Dixie at St Joseph" "18:31:00"
190 "t6D1-b9C-sl1D" "1" 435.43655628030837 0.4838183958670093 47681 2756 "301451" "Dixie at Hilton" "18:30:56" 47682 2760 "301461" "Dixie at St Joseph" "18:31:00"
198 "t799-b9F-sl1D" "1" 435.43655628030837 0.4838183958670093 55570 2756 "301451" "Dixie at Hilton" "20:30:56" 55571 2760 "301461" "Dixie at St Joseph" "20:31:00"
61 "t799-b28A-sl1B" "1" 435.43655628030837 0.4838183958670093 55570 2756 "301451" "Dixie at Hilton" "20:30:56" 55571 2760 "301461" "Dixie at St Joseph" "20:31:00"
128 "t799-b2EE-sl1C" "1" 435.43655628030837 0.4838183958670093 55570 2756 "301451" "Dixie at Hilton" "20:30:56" 55571 2760 "301461" "Dixie at St Joseph" "20:31:00"
110 "t5EB-b2EE-sl1C" "1" 435.43655628030837 0.4838183958670093 37324 2756 "301451" "Dixie at Hilton" "16:00:56" 37325 2760 "301461" "Dixie at St Joseph" "16:01:00"
43 "t5EB-b28A-sl1B" "1" 435.43655628030837 0.4838183958670093 37324 2756 "301451" "Dixie at Hilton" "16:00:56" 37325 2760 "301461" "Dixie at St Joseph" "16:01:00"
73 "t267-b2CC-sl1C" "1" 435.43655628030837 0.4838183958670093 3775 2756 "301451" "Dixie at Hilton" "07:00:56" 3776 2760 "301461" "Dixie at St Joseph" "07:01:00"
6 "t267-b268-sl1B" "1" 435.43655628030837 0.4838183958670093 3775 2756 "301451" "Dixie at Hilton" "07:00:56" 3776 2760 "301461" "Dixie at St Joseph" "07:01:00"
40 "t5A5-b27D-sl1B" "1" 435.43655628030837 0.4838183958670093 35340 2756 "301451" "Dixie at Hilton" "15:30:56" 35341 2760 "301461" "Dixie at St Joseph" "15:31:00"
178 "t5A5-b9D-sl1D" "1" 435.43655628030837 0.4838183958670093 35340 2756 "301451" "Dixie at Hilton" "15:30:56" 35341 2760 "301461" "Dixie at St Joseph" "15:31:00"
107 "t5A5-b2E1-sl1C" "1" 435.43655628030837 0.4838183958670093 35340 2756 "301451" "Dixie at Hilton" "15:30:56" 35341 2760 "301461" "Dixie at St Joseph" "15:31:00"
112 "t609-b2E4-sl1C" "1" 435.43655628030837 0.4838183958670093 39584 2756 "301451" "Dixie at Hilton" "16:30:56" 39585 2760 "301461" "Dixie at St Joseph" "16:31:00"
45 "t609-b280-sl1B" "1" 435.43655628030837 0.4838183958670093 39584 2756 "301451" "Dixie at Hilton" "16:30:56" 39585 2760 "301461" "Dixie at St Joseph" "16:31:00"
183 "t609-bA3-sl1D" "1" 435.43655628030837 0.4838183958670093 39584 2756 "301451" "Dixie at Hilton" "16:30:56" 39585 2760 "301461" "Dixie at St Joseph" "16:31:00"
50 "t6B3-b27C-sl1B" "1" 435.43655628030837 0.4838183958670093 45260 2756 "301451" "Dixie at Hilton" "18:00:56" 45261 2760 "301461" "Dixie at St Joseph" "18:01:00"
117 "t6B3-b2E0-sl1C" "1" 435.43655628030837 0.4838183958670093 45260 2756 "301451" "Dixie at Hilton" "18:00:56" 45261 2760 "301461" "Dixie at St Joseph" "18:01:00"
188 "t6B3-b9B-sl1D" "1" 435.43655628030837 0.4838183958670093 45260 2756 "301451" "Dixie at Hilton" "18:00:56" 45261 2760 "301461" "Dixie at St Joseph" "18:01:00"
49 "t66D-b284-sl1B" "1" 435.43655628030837 0.4838183958670093 43402 2756 "301451" "Dixie at Hilton" "17:30:56" 43403 2760 "301461" "Dixie at St Joseph" "17:31:00"
116 "t66D-b2E8-sl1C" "1" 435.43655628030837 0.4838183958670093 43402 2756 "301451" "Dixie at Hilton" "17:30:56" 43403 2760 "301461" "Dixie at St Joseph" "17:31:00"
187 "t66D-bB7-sl1D" "1" 435.43655628030837 0.4838183958670093 43402 2756 "301451" "Dixie at Hilton" "17:30:56" 43403 2760 "301461" "Dixie at St Joseph" "17:31:00"
28 "t479-b264-sl1B" "1" 435.43655628030837 0.4838183958670093 23947 2756 "301451" "Dixie at Hilton" "12:30:56" 23948 2760 "301461" "Dixie at St Joseph" "12:31:00"
167 "t479-b73-sl1D" "1" 435.43655628030837 0.4838183958670093 23947 2756 "301451" "Dixie at Hilton" "12:30:56" 23948 2760 "301461" "Dixie at St Joseph" "12:31:00"
95 "t479-b2C8-sl1C" "1" 435.43655628030837 0.4838183958670093 23947 2756 "301451" "Dixie at Hilton" "12:30:56" 23948 2760 "301461" "Dixie at St Joseph" "12:31:00"
105 "t587-b2C2-sl1C" "1" 435.43655628030837 0.4838183958670093 33379 2756 "301451" "Dixie at Hilton" "15:00:56" 33380 2760 "301461" "Dixie at St Joseph" "15:01:00"
38 "t587-b25E-sl1B" "1" 435.43655628030837 0.4838183958670093 33379 2756 "301451" "Dixie at Hilton" "15:00:56" 33380 2760 "301461" "Dixie at St Joseph" "15:01:00"
176 "t587-b77-sl1D" "1" 435.43655628030837 0.4838183958670093 33379 2756 "301451" "Dixie at Hilton" "15:00:56" 33380 2760 "301461" "Dixie at St Joseph" "15:01:00"
157 "t393-b6B-sl1D" "1" 435.43655628030837 0.4838183958670093 14871 2756 "301451" "Dixie at Hilton" "10:00:56" 14872 2760 "301461" "Dixie at St Joseph" "10:01:00"
19 "t393-b270-sl1B" "1" 435.43655628030837 0.4838183958670093 14871 2756 "301451" "Dixie at Hilton" "10:00:56" 14872 2760 "301461" "Dixie at St Joseph" "10:01:00"
86 "t393-b2D4-sl1C" "1" 435.43655628030837 0.4838183958670093 14871 2756 "301451" "Dixie at Hilton" "10:00:56" 14872 2760 "301461" "Dixie at St Joseph" "10:01:00"
139 "t1BD-b6B-sl1D" "1" 435.43655628030837 0.4838183958670093 647 2756 "301451" "Dixie at Hilton" "05:30:56" 648 2760 "301461" "Dixie at St Joseph" "05:31:00"
1631 "t2DA-b79-sl1D" "552" 348.34924502424667 0.4838183958670093 8870 47 "301451" "Dixie at Hilton" "07:30:47" 8871 52 "301461" "Dixie at St Joseph" "07:30:52"
132 "t861-b2E8-sl1C" "1" 435.43655628030837 0.4838183958670093 61630 2756 "301451" "Dixie at Hilton" "22:30:56" 61631 2760 "301461" "Dixie at St Joseph" "22:31:00"
203 "t861-bB7-sl1D" "1" 435.43655628030837 0.4838183958670093 61630 2756 "301451" "Dixie at Hilton" "22:30:56" 61631 2760 "301461" "Dixie at St Joseph" "22:31:00"
65 "t861-b284-sl1B" "1" 435.43655628030837 0.4838183958670093 61630 2756 "301451" "Dixie at Hilton" "22:30:56" 61631 2760 "301461" "Dixie at St Joseph" "22:31:00"
94 "t45B-b2C3-sl1C" "1" 435.43655628030837 0.4838183958670093 22130 2756 "301451" "Dixie at Hilton" "12:00:56" 22131 2760 "301461" "Dixie at St Joseph" "12:01:00"
27 "t45B-b25F-sl1B" "1" 435.43655628030837 0.4838183958670093 22130 2756 "301451" "Dixie at Hilton" "12:00:56" 22131 2760 "301461" "Dixie at St Joseph" "12:01:00"
164 "t45B-b68-sl1D" "1" 435.43655628030837 0.4838183958670093 22130 2756 "301451" "Dixie at Hilton" "12:00:56" 22131 2760 "301461" "Dixie at St Joseph" "12:01:00"
144 "t267-b64-sl1D" "1" 435.43655628030837 0.4838183958670093 3895 2756 "301451" "Dixie at Hilton" "07:00:56" 3896 2760 "301461" "Dixie at St Joseph" "07:01:00"
missing_feed_contact_email_and_url WARNING 1

missing_feed_contact_email_and_url

Best Practices for feed_info.txt suggest providing at least one of feed_contact_email and feed_contact_url.

You can see more about this notice here.

csvRowNumber (?) The row number of the validated record.
2
mixed_case_recommended_field WARNING 4

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.

filename (?) Name of the faulty file. fieldName (?) Name of the faulty field. fieldValue (?) Faulty value. csvRowNumber (?) The row number of the faulty record.
"stops.txt" "stop_name" "30th at 31st" 684
"stops.txt" "stop_name" "30th at 31st" 694
"trips.txt" "trip_headsign" "null" 1506
"trips.txt" "trip_headsign" "null" 1507
route_long_name_contains_short_name WARNING 1

route_long_name_contains_short_name

Long name should not contain short name for a single route.

In routes.txt, route_long_name should not contain the value for route_short_name, because when both are provided, they are often combined by transit applications. Note that only one of the two fields is required. If there is no short name used for a route, use route_long_name only.

Good examples:

route_short_name/route_long_name Dataset
"N"/"Judah" Muni San Fransisco
"6"/"ML King Jr Blvd" Trimet Portland Streetcar
"55"/"Boulevard Saint Laurent" STM Montreal
"1"/"Rangiora/Cashmere" Metro Christchurch

Bad examples:

route_short_name/route_long_name
"604"/"604"
"14"/"Route 14"
"2"/"Route 2: Bellows Falls In-Town"

You can see more about this notice here.

routeId (?) The id of the faulty record. csvRowNumber (?) The row number of the faulty record. routeShortName (?) The faulty record's `route_short_name`. routeLongName (?) The faulty record's `route_long_name`.
"64" 10 "64" "64"
same_name_and_description_for_route WARNING 10

same_name_and_description_for_route

Same name and description for route.

The GTFS spec defines routes.txt route_desc as:

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

See the GTFS and GTFS Best Practices links below for more examples of how to populate the route_short_name, route_long_name, and route_desc fields.

You can see more about this notice here.

csvRowNumber (?) The row number of the faulty record. routeId (?) The id of the faulty record. routeDesc (?) The `routes.routes_desc` of the faulty record. specifiedField (?) Either `route_short_name` or `route_long_name`.
12 "352" "Holmes HS #3 PM" "route_long_name"
13 "450" "Holmes HS #2 PM" "route_long_name"
14 "451" "Holmes HS #2 AM" "route_long_name"
15 "485" "Holmes HS #5 PM" "route_long_name"
16 "552" "Holmes HS #1 AM" "route_long_name"
17 "553" "Holmes HS #6 PM" "route_long_name"
18 "652" "Holmes HS #8 AM" "route_long_name"
19 "751" "Holmes HS #7 PM" "route_long_name"
20 "752" "Holmes HS #9 PM" "route_long_name"
21 "851" "Holmes HS #4 PM" "route_long_name"
stop_too_far_from_shape_using_user_distance WARNING 30

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.
1912 "4009_shp" "t5EB-bB1-sl1D" 37534 "332" "Decoursey at E 39th" [39.04698435488196,-84.50270406499463] 281.7075023872674
1912 "4009_shp" "t5EB-bB1-sl1D" 37535 "333" "Decoursey at E 41st" [39.04495199674955,-84.50017313722428] 280.93910387551165
1912 "4009_shp" "t5EB-bB1-sl1D" 37536 "334" "Decoursey at E 42nd" [39.04417525328003,-84.49989527238723] 307.126437794465
1912 "4009_shp" "t5EB-bB1-sl1D" 37537 "335" "Decoursey at E 43rd" [39.04301785653428,-84.49937623294227] 307.70658644961964
1912 "4009_shp" "t5EB-bB1-sl1D" 37538 "336" "Decoursey at 44th" [39.04183591976569,-84.49849782868463] 307.76134864430304
1912 "4009_shp" "t5EB-bB1-sl1D" 37539 "337" "Decoursey at E 45th" [39.0399970819949,-84.49712434189374] 304.54468162565433
1912 "4009_shp" "t5EB-bB1-sl1D" 37540 "71" "45th at Huntington" [39.03925422138887,-84.49657638101469] 266.0032120288593
1912 "4009_shp" "t5EB-bB1-sl1D" 37541 "693" "Huntington at 41st" [39.040306742116655,-84.49562646097438] 307.94787964766493
1912 "4009_shp" "t5EB-bB1-sl1D" 37542 "692" "Huntington at 39th" [39.042017971458066,-84.4962338973937] 294.42986668979313
1912 "4009_shp" "t5EB-bB1-sl1D" 37543 "694" "Huntington at E Southern" [39.04489550021656,-84.49765491395495] 308.9693847690769
1912 "4009_shp" "t5EB-bB1-sl1D" 37544 "519" "E Southern at Lincoln" [39.04625458931943,-84.49814159270369] 244.86062890221788
1912 "4009_shp" "t5EB-bB1-sl1D" 37545 "1059" "Southern at Church" [39.04749413048897,-84.49864473443897] 307.0219948593856
581 "4143_shp" "t196-b65-sl1D" 114 "102120" "Wendell Ford at Amazon Prime Air" [39.033213999999994,-84.657934] 109.85610348821965
581 "4143_shp" "t196-b65-sl1D" 115 "102130" "Aero Pkwy at Bosch" [39.0190846900784,-84.64851727417783] 108.7215258166077
581 "4143_shp" "t196-b65-sl1D" 117 "102140" "Thoroughbred at Hansel" [39.01761936007845,-84.63824185567148] 112.14269304175089
494 "4185_shp" "t196-b2BC-sl1C" 97 "102120" "Wendell Ford at Amazon Prime Air" [39.033213999999994,-84.657934] 109.85610348821965
494 "4185_shp" "t196-b2BC-sl1C" 98 "102130" "Aero Pkwy at Bosch" [39.0190846900784,-84.64851727417783] 108.7215258166077
494 "4185_shp" "t196-b2BC-sl1C" 100 "102140" "Thoroughbred at Hansel" [39.01761936007845,-84.63824185567148] 112.14269304175089
1526 "4175_shp" "t2DA-b95-sl1D" 8940 "308120" "15th at Greenup" [39.074163,-84.504495] 100.59013609456719
1526 "4175_shp" "t2DA-b95-sl1D" 8942 "1048" "Scott at 17th" [39.07199492603337,-84.50546000941509] 112.07297140143197
1526 "4175_shp" "t2DA-b95-sl1D" 8943 "1050" "Scott at 19th" [39.069553255215524,-84.50486067165912] 112.05924329048615
1526 "4175_shp" "t2DA-b95-sl1D" 8944 "1051" "Scott at 20th" [39.068315433244926,-84.50455188074136] 112.13791584224525
1526 "4175_shp" "t2DA-b95-sl1D" 8946 "305350" "Madison at Wallace" [39.06660303728707,-84.50577479711524] 112.130121334309
1526 "4175_shp" "t2DA-b95-sl1D" 8947 "305360" "Madison at Sterrett" [39.06509468179961,-84.5053980443752] 112.12498744020336
1526 "4175_shp" "t2DA-b95-sl1D" 8948 "305370" "Madison at 24th" [39.064239036673804,-84.50519019873317] 112.17721986939245
1526 "4175_shp" "t2DA-b95-sl1D" 8949 "305380" "Madison at Catalpa" [39.06329143426117,-84.50495677271068] 109.39784589346287
1526 "4175_shp" "t2DA-b95-sl1D" 8950 "305390" "Madison at 25th" [39.061763221982936,-84.50455686022568] 115.04706022124545
407 "4255_shp" "t196-b258-sl1B" 80 "102120" "Wendell Ford at Amazon Prime Air" [39.033213999999994,-84.657934] 109.85610348821965
407 "4255_shp" "t196-b258-sl1B" 81 "102130" "Aero Pkwy at Bosch" [39.0190846900784,-84.64851727417783] 108.7215258166077
407 "4255_shp" "t196-b258-sl1B" 83 "102140" "Thoroughbred at Hansel" [39.01761936007845,-84.63824185567148] 112.14269304175089
trip_headsign_matches_intermediate_stop INFO 4

trip_headsign_matches_intermediate_stop

Trip headsign matches the name of an intermediate stop, not the last stop.

The trip_headsign matches the stop_name of a stop that is not the last stop of the trip. This may confuse passengers boarding after that stop, since the headsign suggests the vehicle is heading to a stop it has already passed.

You can see more about this notice here.

csvRowNumber (?) The row number of the faulty record in `trips.txt`. tripId (?) The id of the trip with the problematic headsign. tripHeadsign (?) The headsign value that matches an intermediate stop name. stopId1 (?) The id of the intermediate stop whose name matches the headsign. stopSequence (?) The stop_sequence value of the intermediate stop that matches the headsign. stopId2 (?) The id of the actual last stop of the trip.
963 "t285-b26E-sl1B" "Lake Park Drive" "330110" 1724 "330122"
966 "t285-b2D2-sl1C" "Lake Park Drive" "330110" 1724 "330122"
970 "t280-b90-sl1D" "Lake Park Drive" "330110" 1839 "330122"
972 "t2C9-b93-sl1D" "Lake Park Drive" "330110" 1839 "330122"