GTFS Schedule Validation Report

This report was generated by the Canonical GTFS Schedule validator, version 5.0.1 at 2024-06-07T15:51:13Z,
for the dataset file:///tmp/1_in.zip. No country code was provided.

Use this report alongside our documentation.

Summary

Agencies included


Feed Info


Publisher Name:
N/A
Publisher URL:
N/A
Feed Language:
N/A

Files included


  1. agency.txt
  2. calendar.txt
  3. calendar_dates.txt
  4. routes.txt
  5. shapes.txt
  6. stop_times.txt
  7. stops.txt
  8. trips.txt

Counts


  • Agencies: 1
  • Blocks: 7
  • Routes: 2
  • Shapes: 16
  • Stops: 145
  • Trips: 62

GTFS Features included (?) GTFS features provide a standardized vocabulary to define and describe features that are officially adopted in GTFS.


ShapesRoute ColorsHeadsignsWheelchair AccessibilityBikes AllowanceLocation Types

Specification Compliance report

233 notices reported (4 errors, 229 warnings, 0 infos)

Notice Code Severity Total
block_trips_with_overlapping_stop_times ERROR 4

block_trips_with_overlapping_stop_times

Trips with the same block id have overlapping stop times.

You can see more about this notice here.

csvRowNumberA (?) The row number from `trips.txt` of the first faulty trip. tripIdA (?) The id of first faulty trip. serviceIdA (?) The service id of the first faulty trip. csvRowNumberB (?) The row number from `trips.txt` of the second faulty trip. tripIdB (?) The id of the other faulty trip. serviceIdB (?) The service id of the other faulty trip. blockId (?) The `trips.block_id` of the overlapping trip. intersection (?) The overlapping period.
2 "2_06h20_Peupleraie" "1" 3 "1_06h28_Faisanderie" "1" "TAD" "20231113"
2 "2_06h20_Peupleraie" "1" 4 "1_06h27_Chateau_d_Eau" "1" "TAD" "20231113"
3 "1_06h28_Faisanderie" "1" 4 "1_06h27_Chateau_d_Eau" "1" "TAD" "20231113"
4 "1_06h27_Chateau_d_Eau" "1" 8 "2_07h00_ZAD" "1" "TAD" "20231113"
equal_shape_distance_diff_coordinates_distance_below_threshold WARNING 1

equal_shape_distance_diff_coordinates_distance_below_threshold

Two consecutive points have equal shape_dist_traveled and different lat/lon coordinates in shapes.txt and the distance between the two points is less than 1.11m.

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 small difference of coordinates (less than 1.11 m distance) result in a warning.

You can see more about this notice here.

shapeId (?) The id of the faulty shape. csvRowNumber (?) The row number from `shapes.txt`. shapeDistTraveled (?) The faulty record's `shape_dist_traveled` value. shapePtSequence (?) The faulty record's `shapes.shape_pt_sequence`. prevCsvRowNumber (?) The row number from `shapes.txt` of the previous shape point. prevShapeDistTraveled (?) The previous shape point's `shape_dist_traveled` value. prevShapePtSequence (?) The previous record's `shapes.shape_pt_sequence`. actualDistanceBetweenShapePoints (?) Actual distance traveled along the shape from the first shape point to the previous shape point.
"222R01" 6150 5621.0 199 6149 5621.0 198 0.17289456883869078
missing_recommended_column WARNING 1

missing_recommended_column

A recommended column is missing in the input file.

You can see more about this notice here.

filename (?) The name of the faulty file. fieldName (?) The name of the missing column.
"stop_times.txt" "timepoint"
missing_recommended_file WARNING 1

missing_recommended_file

A recommended file is missing.

You can see more about this notice here.

filename (?) The name of the faulty file.
"feed_info.txt"
mixed_case_recommended_field WARNING 167

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 167 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.
"stops.txt" "stop_name" "CHANTEHEUX CHATEAU D'EAU" 2
"stops.txt" "stop_name" "CHANTEHEUX CHATEAU D'EAU" 3
"stops.txt" "stop_name" "CHANTEHEUX CHATEAU D'EAU" 4
"stops.txt" "stop_name" "CHANTEHEUX DE GAULLE" 5
"stops.txt" "stop_name" "CHANTEHEUX DE GAULLE" 6
"stops.txt" "stop_name" "CHANTEHEUX DE GAULLE" 7
"stops.txt" "stop_name" "CHANTEHEUX HAUT DU RIVAGE" 8
"stops.txt" "stop_name" "CHANTEHEUX HAUT DU RIVAGE" 9
"stops.txt" "stop_name" "CHANTEHEUX HAUT DU RIVAGE" 10
"stops.txt" "stop_name" "CHANTEHEUX LIBERTE" 11
"stops.txt" "stop_name" "CHANTEHEUX LIBERTE" 12
"stops.txt" "stop_name" "CHANTEHEUX LIBERTE" 13
"stops.txt" "stop_name" "CHANTEHEUX MAIRIE" 14
"stops.txt" "stop_name" "CHANTEHEUX MAIRIE" 15
"stops.txt" "stop_name" "CHANTEHEUX MAIRIE" 16
"stops.txt" "stop_name" "CHANTEHEUX PAQUIS" 17
"stops.txt" "stop_name" "CHANTEHEUX PAQUIS" 18
"stops.txt" "stop_name" "CHANTEHEUX PAQUIS" 19
"stops.txt" "stop_name" "CHANTEHEUX ZAD" 20
"stops.txt" "stop_name" "CHANTEHEUX ZAD" 21
"stops.txt" "stop_name" "JOLIVET PAUL ERARD" 22
"stops.txt" "stop_name" "JOLIVET PAUL ERARD" 23
"stops.txt" "stop_name" "JOLIVET PAUL ERARD" 24
"stops.txt" "stop_name" "JOLIVET SCHOUMACHER" 25
"stops.txt" "stop_name" "JOLIVET SCHOUMACHER" 26
"stops.txt" "stop_name" "JOLIVET SCHOUMACHER" 27
"stops.txt" "stop_name" "LUNEVILLE JEANNE D'ARC" 28
"stops.txt" "stop_name" "LUNEVILLE JEANNE D'ARC" 29
"stops.txt" "stop_name" "LUNEVILLE JEANNE D'ARC" 30
"stops.txt" "stop_name" "LUNEVILLE 2BCP" 31
"stops.txt" "stop_name" "LUNEVILLE 2BCP" 32
"stops.txt" "stop_name" "LUNEVILLE 2BCP" 33
"stops.txt" "stop_name" "LUNEVILLE BOFFRAND" 34
"stops.txt" "stop_name" "LUNEVILLE BOFFRAND" 35
"stops.txt" "stop_name" "LUNEVILLE BOFFRAND" 36
"stops.txt" "stop_name" "LUNEVILLE BOUTET DE MONVEL" 37
"stops.txt" "stop_name" "LUNEVILLE BOUTET DE MONVEL" 38
"stops.txt" "stop_name" "LUNEVILLE BOUTET DE MONVEL" 39
"stops.txt" "stop_name" "LUNEVILLE CADETS" 40
"stops.txt" "stop_name" "LUNEVILLE CADETS" 41
"stops.txt" "stop_name" "LUNEVILLE CADETS" 42
"stops.txt" "stop_name" "LUNEVILLE CARMES" 43
"stops.txt" "stop_name" "LUNEVILLE CARMES" 44
"stops.txt" "stop_name" "LUNEVILLE CARMES" 45
"stops.txt" "stop_name" "LUNEVILLE CASTARA" 47
"stops.txt" "stop_name" "LUNEVILLE CHATEAU" 48
"stops.txt" "stop_name" "LUNEVILLE CHATEAU" 49
"stops.txt" "stop_name" "LUNEVILLE CHATEAU" 50
"stops.txt" "stop_name" "LUNEVILLE CHERON" 51
"stops.txt" "stop_name" "LUNEVILLE CHERON" 52
route_long_name_contains_short_name WARNING 2

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`.
"1" 2 "L01" "L01 : Faisanderie / Chateau d'eau"
"2" 3 "L02" "L02 : Peupleraie / ZAD"
stop_too_far_from_shape_using_user_distance WARNING 18

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.
2 "222A01" "2_06h20_Peupleraie" 10 "69" "LUNEVILLE DUVAL" [48.58753725326889,6.487873844589983] 287.46690778522077
2 "222A01" "2_06h20_Peupleraie" 11 "136" "LUNEVILLE SAINT CHARLES" [48.58773705470903,6.484398254782303] 338.37558113728045
2 "222A01" "2_06h20_Peupleraie" 12 "826" "LUNEVILLE Castara" [48.586769230931765,6.486482308371012] 560.0585589162633
2 "222A01" "2_06h20_Peupleraie" 13 "110" "LUNEVILLE LEOPOLD" [48.59073199991928,6.491638000218838] 223.59082839611233
2 "222A01" "2_06h20_Peupleraie" 14 "93" "LUNEVILLE HOPITAL" [48.589879356488396,6.495202256913301] 212.49951817142963
2 "222A01" "2_06h20_Peupleraie" 15 "81" "LUNEVILLE GARE SNCF" [48.59050318811187,6.493488051600953] 320.4505514225505
2 "222A01" "2_06h20_Peupleraie" 16 "96" "LUNEVILLE JEANNE D'ARC" [48.58810201945884,6.495569874626377] 604.3169142832998
2 "222A01" "2_06h20_Peupleraie" 17 "27" "LUNEVILLE 2BCP" [48.588943333355644,6.500143333376566] 422.7383302965225
2 "222A01" "2_06h20_Peupleraie" 18 "129" "LUNEVILLE PISCINE" [48.591820006892156,6.508437495420794] 331.5263217940441
2 "222A01" "2_06h20_Peupleraie" 19 "41" "LUNEVILLE CHAMPAGNE" [48.59269666733901,6.505260000308555] 350.74654355468897
2 "222A01" "2_06h20_Peupleraie" 20 "125" "LUNEVILLE PAUL LAPIE" [48.594034307751365,6.5082541539196] 450.28513192508467
2 "222A01" "2_06h20_Peupleraie" 21 "13" "CHANTEHEUX LIBERTE" [48.5979192577594,6.511810534716245] 551.0697663801869
2 "222A01" "2_06h20_Peupleraie" 22 "11" "CHANTEHEUX HAUT DU RIVAGE" [48.59820244494542,6.516043333492895] 507.19760548777293
2 "222A01" "2_06h20_Peupleraie" 23 "5" "CHANTEHEUX CHATEAU D'EAU" [48.596915982324234,6.51912101233013] 610.1724308239062
2 "222A01" "2_06h20_Peupleraie" 24 "15" "CHANTEHEUX MAIRIE" [48.59828668365131,6.523190035041361] 594.1767152119523
2 "222A01" "2_06h20_Peupleraie" 25 "18" "CHANTEHEUX PAQUIS" [48.6001227273084,6.529219091096407] 468.34371570223686
2 "222A01" "2_06h20_Peupleraie" 26 "8" "CHANTEHEUX DE GAULLE" [48.59812205966974,6.534115881149167] 355.4615371767041
2 "222A01" "2_06h20_Peupleraie" 27 "20" "CHANTEHEUX ZAD" [48.59675455328603,6.529911958992105] 502.81236932262755
trip_distance_exceeds_shape_distance_below_threshold WARNING 39

trip_distance_exceeds_shape_distance_below_threshold

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

You can see more about this notice here.

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.
"1_06h28_Faisanderie" "221A01" 10365.0 10358.0 1.588863778743404
"1_06h27_Chateau_d_Eau" "221R01" 11000.0 10995.0 0.6992266579349448
"1_06h48_Jolivet" "221A03" 13660.0 13650.0 1.588863778743404
"1_06h59_Chateau_d_Eau" "221R02" 9012.0 9006.0 2.8555297063888814
"1_07h30_Chateau_d_Eau" "221R01" 11000.0 10995.0 0.6992266579349448
"1_07h31_Jolivet" "221A02" 8434.0 8432.0 1.588863778743404
"1_08h02_Chateau_d_Eau" "221R02" 9012.0 9006.0 2.8555297063888814
"1_08h04_Faisanderie" "221A01" 10365.0 10358.0 1.588863778743404
"1_08h34_Jolivet" "221A02" 8434.0 8432.0 1.588863778743404
"1_08h44_Chateau_d_Eau" "221R03" 10150.0 10145.0 4.593526446191908
"1_09h17_Gregoire" "221A05" 9575.0 9569.0 1.588863778743404
"1_09h28_Chateau_d_Eau" "221R03" 10150.0 10145.0 4.593526446191908
"1_10h06_Gregoire" "221A06" 9517.0 9512.0 6.566474107737537
"1_10h33_Chateau_d_Eau" "221R03" 10150.0 10145.0 4.593526446191908
"1_11h06_Gregoire" "221A05" 9575.0 9569.0 1.588863778743404
"1_11h32_Ecosseuse" "221R07" 10029.0 10025.0 4.593526446191908
"1_12h06_Gregoire" "221A05" 9575.0 9569.0 1.588863778743404
"1_12h18_Jolivet" "221A04" 9073.0 9067.0 0.6288586846653763
"1_12h33_Chateau_d_Eau" "221R04" 4344.0 4342.0 6.307863967279655
"1_12h58_Faisanderie" "221A01" 10365.0 10358.0 1.588863778743404
"1_13h16_Gare" "221R05" 9659.0 9652.0 2.8555297063888814
"1_13h32_Chateau_d_Eau" "221R01" 11000.0 10995.0 0.6992266579349448
"1_14h00_Faisanderie" "221A01" 10365.0 10358.0 1.588863778743404
"1_14h35_Chateau_d_Eau" "221R03" 10150.0 10145.0 4.593526446191908
"1_15h07_Gregoire" "221A06" 9517.0 9512.0 6.566474107737537
"1_15h30_Chateau_d_Eau" "221R03" 10150.0 10145.0 4.593526446191908
"1_16h00_Chateau_d_Eau" "221R02" 9012.0 9006.0 2.8555297063888814
"1_16h02_Gregoire" "221A06" 9517.0 9512.0 6.566474107737537
"1_16h32_Jolivet" "221A02" 8434.0 8432.0 1.588863778743404
"1_16h35_Chateau_d_Eau" "221R03" 10150.0 10145.0 4.593526446191908
"1_17h06_Gregoire" "221A05" 9575.0 9569.0 1.588863778743404
"1_17h25_Chateau_d_Eau" "221R01" 11000.0 10995.0 0.6992266579349448
"1_17h34_Jolivet" "221A02" 8434.0 8432.0 1.588863778743404
"1_17h59_Faisanderie" "221A01" 10365.0 10358.0 1.588863778743404
"1_18h27_Chateau_d_Eau" "221R01" 11000.0 10995.0 0.6992266579349448
"1_18h37_Jolivet" "221A02" 8434.0 8432.0 1.588863778743404
"1_19h01_Faisanderie" "221A01" 10365.0 10358.0 1.588863778743404
"1_19h28_Faisanderie" "221A01" 10365.0 10358.0 1.588863778743404
"1_19h34_Chateau_d_Eau" "221R06" 14003.0 13994.0 2.8555297063888814