northern-perimeter-4 — Source Data Validation Report

This report was generated by the Canonical GTFS Schedule validator, version 7.1.0 at 2026-05-15T21:33:26Z,
for the dataset file:///shared/northern-perimeter-4_cbe2a22b.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


Feed Info


Publisher Name:
CAR_HDF_59_4
Feed Email:
opendata@hautsdefrance.fr
Feed Language:
French
Feed Start Date:
2026-03-02
Feed End Date:
2026-08-31

Files included


  1. agency.txt
  2. calendar.txt
  3. calendar_dates.txt
  4. feed_info.txt
  5. routes.txt
  6. shapes.txt
  7. stop_times.txt
  8. stops.txt
  9. thermometre.txt
  10. timetables.txt
  11. trips.txt

Counts


  • Agencies: 1
  • Blocks: 0
  • Routes: 54
  • Shapes: 0
  • Stops: 1728
  • Trips: 737

Specification Compliance report

27744 notices reported (13473 errors, 14269 warnings, 2 infos)

Notice Code Severity Total
decreasing_or_equal_stop_time_distance ERROR 13472

decreasing_or_equal_stop_time_distance

Decreasing or equal shape_dist_traveled in stop_times.txt.

When sorted by stop_times.stop_sequence, two consecutive entries in stop_times.txt should have increasing distance, based on the field shape_dist_traveled. If the values are equal, this is considered as an error.

You can see more about this notice here.

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

tripId (?) The id of the faulty trip. stopId (?) The id of the faulty stop. csvRowNumber (?) The row number from `stop_times.txt`. shapeDistTraveled (?) Actual distance traveled along the shape from the first shape point to the faulty record. stopSequence (?) The faulty record's `stop_times.stop_sequence`. prevCsvRowNumber (?) The row number from `stop_times.txt` of the previous stop time. prevShapeDistTraveled (?) Actual distance traveled along the shape from the first shape point to the previous stop time. prevStopSequence (?) The previous record's `stop_times.stop_sequence`.
"956S-381" "59:60100" 6055 0.0 2 6054 0.0 1
"956S-381" "59:60153" 6056 0.0 3 6055 0.0 2
"956S-381" "59:26150" 6057 0.0 4 6056 0.0 3
"956S-381" "59:26153" 6058 0.0 5 6057 0.0 4
"956S-381" "59:26151" 6059 0.0 6 6058 0.0 5
"956S-381" "59:26154" 6060 0.0 7 6059 0.0 6
"956S-381" "59:26152" 6061 0.0 8 6060 0.0 7
"976S-323" "59:05301" 9319 0.0 2 9318 0.0 1
"976S-323" "59:31502" 9320 0.0 3 9319 0.0 2
"976S-323" "59:31550" 9321 0.0 4 9320 0.0 3
"976S-323" "59:31054" 9322 0.0 5 9321 0.0 4
"976S-323" "59:31052" 9323 0.0 6 9322 0.0 5
"976S-323" "59:31053" 9324 0.0 7 9323 0.0 6
"976S-323" "59:31051" 9325 0.0 8 9324 0.0 7
"976S-323" "59:31050" 9326 0.0 9 9325 0.0 8
"976S-323" "59:58457" 9327 0.0 10 9326 0.0 9
"976S-323" "59:58452" 9328 0.0 11 9327 0.0 10
"976S-323" "59:58451" 9329 0.0 12 9328 0.0 11
"976S-323" "59:58455" 9330 0.0 13 9329 0.0 12
"990-51" "59:48102" 13726 0.0 2 13725 0.0 1
"990-51" "59:48108" 13727 0.0 3 13726 0.0 2
"990-51" "59:48101" 13728 0.0 4 13727 0.0 3
"990-51" "59:48107" 13729 0.0 5 13728 0.0 4
"990-51" "59:48109" 13730 0.0 6 13729 0.0 5
"990-51" "59:48149" 13731 0.0 7 13730 0.0 6
"990-51" "59:25100" 13732 0.0 8 13731 0.0 7
"990-51" "59:26551" 13733 0.0 9 13732 0.0 8
"990-51" "59:26552" 13734 0.0 10 13733 0.0 9
"990-51" "59:47350" 13735 0.0 11 13734 0.0 10
"990-51" "59:64002" 13736 0.0 12 13735 0.0 11
"990-51" "59:64001" 13737 0.0 13 13736 0.0 12
"990-51" "59:63900" 13738 0.0 14 13737 0.0 13
"990-51" "59:63951" 13739 0.0 15 13738 0.0 14
"990-51" "59:63953" 13740 0.0 16 13739 0.0 15
"990-51" "59:11650" 13741 0.0 17 13740 0.0 16
"990-51" "59:21750" 13742 0.0 18 13741 0.0 17
"990-51" "59:21751" 13743 0.0 19 13742 0.0 18
"990-51" "59:55950" 13744 0.0 20 13743 0.0 19
"990-51" "59:55958" 13745 0.0 21 13744 0.0 20
"990-51" "59:55961" 13746 0.0 22 13745 0.0 21
"990-51" "59:55959" 13747 0.0 23 13746 0.0 22
"990-51" "59:16663" 13748 0.0 24 13747 0.0 23
"990-51" "59:16601" 13749 0.0 25 13748 0.0 24
"990-51" "59:16602" 13750 0.0 26 13749 0.0 25
"990-51" "59:55701" 13751 0.0 27 13750 0.0 26
"990-51" "59:55700" 13752 0.0 28 13751 0.0 27
"990-51" "59:38309" 13753 0.0 29 13752 0.0 28
"990-51" "59:38300" 13754 0.0 30 13753 0.0 29
"990-51" "59:60609" 13755 0.0 31 13754 0.0 30
"990-51" "59:60608" 13756 0.0 32 13755 0.0 31
stop_time_with_arrival_before_previous_departure_time ERROR 1

stop_time_with_arrival_before_previous_departure_time

Backwards time travel between stops in stop_times.txt

For a given trip_id, the arrival_time of (n+1)-th stoptime in sequence must not precede the departure_time of n-th stoptime in sequence in stop_times.txt.

You can see more about this notice here.

csvRowNumber (?) The row number of the faulty record. prevCsvRowNumber (?) The row of the previous stop time. tripId (?) The trip_id associated to the faulty record. arrivalTime (?) Arrival time at the faulty record. departureTime (?) Departure time at the previous stop time.
6234 6233 "956-60" "17:23:00" "17:27:00"
missing_timepoint_value WARNING 14209

missing_timepoint_value

stop_times.timepoint value is missing for a record.

When at least one of stop_times.arrival_time or stop_times.departure_time are provided, stop_times.timepoint should be defined

You can see more about this notice here.

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

csvRowNumber (?) The row number of the faulty record. tripId (?) The faulty record's `stop_times.trip_id`. stopSequence (?) The faulty record's `stop_times.stop_sequence`.
2 "951S-310" 1
3 "951S-310" 2
4 "951S-310" 3
5 "951S-310" 4
6 "951S-310" 5
7 "951S-310" 6
8 "951S-310" 7
9 "951S-310" 8
10 "951S-310" 9
11 "951S-310" 10
12 "951S-310" 11
13 "951S-310" 12
14 "951S-310" 13
15 "951S-310" 14
16 "951S-310" 15
17 "951S-320" 1
18 "951S-320" 2
19 "951S-320" 3
20 "951S-320" 4
21 "951S-320" 5
22 "951S-320" 6
23 "951S-320" 7
24 "951S-320" 8
25 "951S-320" 9
26 "951S-320" 10
27 "951S-320" 11
28 "951S-330" 1
29 "951S-330" 2
30 "951S-321" 1
31 "951S-321" 2
32 "951S-323" 1
33 "951S-323" 2
34 "951S-323" 3
35 "951S-323" 4
36 "951S-323" 5
37 "951S-323" 6
38 "951S-323" 7
39 "951S-325" 1
40 "951S-325" 2
41 "951S-325" 3
42 "951S-325" 4
43 "951S-325" 5
44 "951S-325" 6
45 "951S-325" 7
46 "951S-325" 8
47 "951S-325" 9
48 "951S-325" 10
49 "951S-325" 11
50 "951S-325" 12
51 "951S-325" 13
mixed_case_recommended_field WARNING 58

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 58 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.
"agency.txt" "agency_name" "CAR_HDF_59_4" 2
"routes.txt" "route_long_name" "MAUBEUGE - VALENCIENNES" 2
"routes.txt" "route_long_name" "MAUBEUGE - VALENCIENNES" 3
"routes.txt" "route_long_name" "MAUBEUGE - FOURMIES" 4
"routes.txt" "route_long_name" "MAUBEUGE - ANOR" 5
"routes.txt" "route_long_name" "LE QUESNOY - PRESEAU - VALENCIENNES" 6
"routes.txt" "route_long_name" "LANDRECIES - LE QUESNOY" 7
"routes.txt" "route_long_name" "SOLRE-LE-CHATEAU - AVESNES-SUR-HELPE" 8
"routes.txt" "route_long_name" "ANOR - FOURMIES - TRELON" 9
"routes.txt" "route_long_name" "AVESNES-SUR-HELPE - AULNOYE-AYMERIES" 10
"routes.txt" "route_long_name" "WIGNEHIES - TRELON" 11
"routes.txt" "route_long_name" "LE QUESNOY - FAMARS" 12
"routes.txt" "route_long_name" "BAVAY - LE QUESNOY" 13
"routes.txt" "route_long_name" "SOLESMES - LE QUESNOY" 14
"routes.txt" "route_long_name" "LANDRECIES - LE CATEAU" 15
"routes.txt" "route_long_name" "LOCQUIGNOL - LE QUESNOY" 16
"routes.txt" "route_long_name" "FEIGNIES - BAVAY" 17
"routes.txt" "route_long_name" "LA FLAMENGRIE - BAVAY" 18
"routes.txt" "route_long_name" "BAVAY - AULNOYE-AYMERIES" 19
"routes.txt" "route_long_name" "BAVAY - MAUBEUGE" 20
"routes.txt" "route_long_name" "GOMMEGNIES - LE QUESNOY" 21
"routes.txt" "route_long_name" "BEAUREPAIRE-SUR-SAMBRE - AVESNES-SUR-HELPE" 22
"routes.txt" "route_long_name" "LANDRECIES - PRISCHES - AVESNES-SUR-HELPE" 23
"routes.txt" "route_long_name" "LIESSIES - FOURMIES" 24
"routes.txt" "route_long_name" "EPPE-SAUVAGE - AVESNES-SUR-HELPE" 25
"routes.txt" "route_long_name" "HESTRUD - JEUMONT" 26
"routes.txt" "route_long_name" "SOLRE-LE-CHATEAU - MAUBEUGE" 27
"routes.txt" "route_long_name" "LANDRECIES - AULNOYE-AYMERIES" 28
"routes.txt" "route_long_name" "SOLRE-LE-CHATEAU - FOURMIES" 29
"routes.txt" "route_long_name" "LANDRECIES - MARBAIX - AVESNES-SUR-HELPE" 30
"routes.txt" "route_long_name" "LE QUESNOY - GOMMEGNIES - VALENCIENNES" 31
"routes.txt" "route_long_name" "MAUBEUGE - VALENCIENNES" 32
"routes.txt" "route_long_name" "MAUBEUGE - FOURMIES" 33
"routes.txt" "route_long_name" "LE QUESNOY - PRESEAU - VALENCIENNES" 34
"routes.txt" "route_long_name" "LANDRECIES - LE QUESNOY" 35
"routes.txt" "route_long_name" "SOLRE-LE-CHATEAU - AVESNES-SUR-HELPE" 36
"routes.txt" "route_long_name" "ANOR - FOURMIES - TRELON" 37
"routes.txt" "route_long_name" "AVESNES-SUR-HELPE - AULNOYE-AYMERIES" 38
"routes.txt" "route_long_name" "WIGNEHIES - TRELON" 39
"routes.txt" "route_long_name" "BAVAY - LE QUESNOY" 40
"routes.txt" "route_long_name" "SOLESMES - LE QUESNOY" 41
"routes.txt" "route_long_name" "LANDRECIES - LE CATEAU" 42
"routes.txt" "route_long_name" "LOCQUIGNOL - LE QUESNOY" 43
"routes.txt" "route_long_name" "FEIGNIES - BAVAY" 44
"routes.txt" "route_long_name" "LA FLAMENGRIE - BAVAY" 45
"routes.txt" "route_long_name" "GOMMEGNIES - LE QUESNOY" 46
"routes.txt" "route_long_name" "BEAUREPAIRE-SUR-SAMBRE - AVESNES-SUR-HELPE" 47
"routes.txt" "route_long_name" "LANDRECIES - PRISCHES - AVESNES-SUR-HELPE" 48
"routes.txt" "route_long_name" "LIESSIES - FOURMIES" 49
"routes.txt" "route_long_name" "HESTRUD - JEUMONT" 50
route_color_contrast WARNING 2

route_color_contrast

Insufficient route color contrast.

A route's color and route_text_color should be contrasting.

You can see more about this notice here.

routeId (?) The id of the faulty record. csvRowNumber (?) The row number of the faulty record. routeColor (?) The faulty record's HTML route color. routeTextColor (?) The faulty record's HTML route text color.
"985" 26 "#FABB00" "#FFFFFF"
"985S" 50 "#FABB00" "#FFFFFF"
unknown_file INFO 2

unknown_file

A file is unknown.

You can see more about this notice here.

filename (?) The name of the unknown file.
"thermometre.txt"
"timetables.txt"