023_OnTimeFlightPerformance(Scala)

This is a scala version of the python notebook in the following talk:

Homework:

See https://www.brighttalk.com/webcast/12891/199003 (you need to subscribe freely to Bright Talk first). Then go through this scala version of the notebook from the talk.

On-Time Flight Performance with GraphFrames for Apache Spark

This notebook provides an analysis of On-Time Flight Performance and Departure Delays data using GraphFrames for Apache Spark.

Source Data:

References:

Preparation

Extract the Airports and Departure Delays information from S3 / DBFS

// Set File Paths
val tripdelaysFilePath = "/databricks-datasets/flights/departuredelays.csv"
val airportsnaFilePath = "/databricks-datasets/flights/airport-codes-na.txt"
tripdelaysFilePath: String = /databricks-datasets/flights/departuredelays.csv airportsnaFilePath: String = /databricks-datasets/flights/airport-codes-na.txt
// Obtain airports dataset
// Note that "spark-csv" package is built-in datasource in Spark 2.0
val airportsna = sqlContext.read.format("com.databricks.spark.csv").
  option("header", "true").
  option("inferschema", "true").
  option("delimiter", "\t").
  load(airportsnaFilePath)

airportsna.createOrReplaceTempView("airports_na")

// Obtain departure Delays data
val departureDelays = sqlContext.read.format("com.databricks.spark.csv").option("header", "true").load(tripdelaysFilePath)
departureDelays.createOrReplaceTempView("departureDelays")
departureDelays.cache()

// Available IATA (International Air Transport Association) codes from the departuredelays sample dataset
val tripIATA = sqlContext.sql("select distinct iata from (select distinct origin as iata from departureDelays union all select distinct destination as iata from departureDelays) a")
tripIATA.createOrReplaceTempView("tripIATA")

// Only include airports with atleast one trip from the departureDelays dataset
val airports = sqlContext.sql("select f.IATA, f.City, f.State, f.Country from airports_na f join tripIATA t on t.IATA = f.IATA")
airports.createOrReplaceTempView("airports")
airports.cache()
airportsna: org.apache.spark.sql.DataFrame = [City: string, State: string ... 2 more fields] departureDelays: org.apache.spark.sql.DataFrame = [date: string, delay: string ... 3 more fields] tripIATA: org.apache.spark.sql.DataFrame = [iata: string] airports: org.apache.spark.sql.DataFrame = [IATA: string, City: string ... 2 more fields] res87: airports.type = [IATA: string, City: string ... 2 more fields]
// Build `departureDelays_geo` DataFrame
// Obtain key attributes such as Date of flight, delays, distance, and airport information (Origin, Destination)  
val departureDelays_geo = sqlContext.sql("select cast(f.date as int) as tripid, cast(concat(concat(concat(concat(concat(concat('2014-', concat(concat(substr(cast(f.date as string), 1, 2), '-')), substr(cast(f.date as string), 3, 2)), ' '), substr(cast(f.date as string), 5, 2)), ':'), substr(cast(f.date as string), 7, 2)), ':00') as timestamp) as `localdate`, cast(f.delay as int), cast(f.distance as int), f.origin as src, f.destination as dst, o.city as city_src, d.city as city_dst, o.state as state_src, d.state as state_dst from departuredelays f join airports o on o.iata = f.origin join airports d on d.iata = f.destination") 

// RegisterTempTable
departureDelays_geo.createOrReplaceTempView("departureDelays_geo")

// Cache and Count
departureDelays_geo.cache()
departureDelays_geo.count()
departureDelays_geo: org.apache.spark.sql.DataFrame = [tripid: int, localdate: timestamp ... 8 more fields] res89: Long = 1361141
display(departureDelays_geo)
10111112014-01-01T11:11:00.000+0000-5221MSPINLMinneapolisInternational FallsMNMN
10211112014-01-02T11:11:00.000+00007221MSPINLMinneapolisInternational FallsMNMN
10311112014-01-03T11:11:00.000+00000221MSPINLMinneapolisInternational FallsMNMN
10419252014-01-04T19:25:00.000+00000221MSPINLMinneapolisInternational FallsMNMN
10611152014-01-06T11:15:00.000+000033221MSPINLMinneapolisInternational FallsMNMN
10711152014-01-07T11:15:00.000+000023221MSPINLMinneapolisInternational FallsMNMN
10811152014-01-08T11:15:00.000+0000-9221MSPINLMinneapolisInternational FallsMNMN
10911152014-01-09T11:15:00.000+000011221MSPINLMinneapolisInternational FallsMNMN
11011152014-01-10T11:15:00.000+0000-3221MSPINLMinneapolisInternational FallsMNMN
11120152014-01-11T20:15:00.000+0000-7221MSPINLMinneapolisInternational FallsMNMN
11219252014-01-12T19:25:00.000+0000-5221MSPINLMinneapolisInternational FallsMNMN
11311152014-01-13T11:15:00.000+0000-3221MSPINLMinneapolisInternational FallsMNMN
11411152014-01-14T11:15:00.000+0000-6221MSPINLMinneapolisInternational FallsMNMN
11511152014-01-15T11:15:00.000+0000-7221MSPINLMinneapolisInternational FallsMNMN
11611152014-01-16T11:15:00.000+0000-3221MSPINLMinneapolisInternational FallsMNMN
11711152014-01-17T11:15:00.000+00004221MSPINLMinneapolisInternational FallsMNMN
11820152014-01-18T20:15:00.000+0000-5221MSPINLMinneapolisInternational FallsMNMN
11919252014-01-19T19:25:00.000+0000-7221MSPINLMinneapolisInternational FallsMNMN
12011152014-01-20T11:15:00.000+0000-6221MSPINLMinneapolisInternational FallsMNMN
12111152014-01-21T11:15:00.000+00000221MSPINLMinneapolisInternational FallsMNMN
12211152014-01-22T11:15:00.000+0000-4221MSPINLMinneapolisInternational FallsMNMN
12311152014-01-23T11:15:00.000+0000-4221MSPINLMinneapolisInternational FallsMNMN
12411152014-01-24T11:15:00.000+0000-3221MSPINLMinneapolisInternational FallsMNMN
12520152014-01-25T20:15:00.000+0000-12221MSPINLMinneapolisInternational FallsMNMN
12619252014-01-26T19:25:00.000+0000-5221MSPINLMinneapolisInternational FallsMNMN
12711152014-01-27T11:15:00.000+00000221MSPINLMinneapolisInternational FallsMNMN
12811152014-01-28T11:15:00.000+0000-8221MSPINLMinneapolisInternational FallsMNMN
12911152014-01-29T11:15:00.000+0000-2221MSPINLMinneapolisInternational FallsMNMN
13011152014-01-30T11:15:00.000+00000221MSPINLMinneapolisInternational FallsMNMN
13111152014-01-31T11:15:00.000+0000-3221MSPINLMinneapolisInternational FallsMNMN
20120152014-02-01T20:15:00.000+0000-4221MSPINLMinneapolisInternational FallsMNMN
20220152014-02-02T20:15:00.000+00000221MSPINLMinneapolisInternational FallsMNMN
20311152014-02-03T11:15:00.000+0000-7221MSPINLMinneapolisInternational FallsMNMN
20411152014-02-04T11:15:00.000+0000-6221MSPINLMinneapolisInternational FallsMNMN
20511152014-02-05T11:15:00.000+0000-4221MSPINLMinneapolisInternational FallsMNMN
20611152014-02-06T11:15:00.000+0000-2221MSPINLMinneapolisInternational FallsMNMN
20711152014-02-07T11:15:00.000+0000-15221MSPINLMinneapolisInternational FallsMNMN
20820152014-02-08T20:15:00.000+0000-4221MSPINLMinneapolisInternational FallsMNMN
20919252014-02-09T19:25:00.000+00001221MSPINLMinneapolisInternational FallsMNMN
21011152014-02-10T11:15:00.000+0000-3221MSPINLMinneapolisInternational FallsMNMN
21111152014-02-11T11:15:00.000+0000-7221MSPINLMinneapolisInternational FallsMNMN
21211152014-02-12T11:15:00.000+0000-2221MSPINLMinneapolisInternational FallsMNMN
21311152014-02-13T11:15:00.000+0000-3221MSPINLMinneapolisInternational FallsMNMN
21411152014-02-14T11:15:00.000+0000-11221MSPINLMinneapolisInternational FallsMNMN
21520152014-02-15T20:15:00.000+000016221MSPINLMinneapolisInternational FallsMNMN
21619252014-02-16T19:25:00.000+0000169221MSPINLMinneapolisInternational FallsMNMN
21711152014-02-17T11:15:00.000+000027221MSPINLMinneapolisInternational FallsMNMN
21811152014-02-18T11:15:00.000+000096221MSPINLMinneapolisInternational FallsMNMN
21911152014-02-19T11:15:00.000+0000-9221MSPINLMinneapolisInternational FallsMNMN
22011152014-02-20T11:15:00.000+0000-6221MSPINLMinneapolisInternational FallsMNMN
22111152014-02-21T11:15:00.000+0000-4221MSPINLMinneapolisInternational FallsMNMN
22220152014-02-22T20:15:00.000+0000-4221MSPINLMinneapolisInternational FallsMNMN
22319252014-02-23T19:25:00.000+0000-3221MSPINLMinneapolisInternational FallsMNMN
22411152014-02-24T11:15:00.000+0000-2221MSPINLMinneapolisInternational FallsMNMN
22511152014-02-25T11:15:00.000+0000-6221MSPINLMinneapolisInternational FallsMNMN
22611152014-02-26T11:15:00.000+0000-8221MSPINLMinneapolisInternational FallsMNMN
22711152014-02-27T11:15:00.000+0000-8221MSPINLMinneapolisInternational FallsMNMN
22811152014-02-28T11:15:00.000+00005221MSPINLMinneapolisInternational FallsMNMN
30120152014-03-01T20:15:00.000+0000-4221MSPINLMinneapolisInternational FallsMNMN
30220002014-03-02T20:00:00.000+00000221MSPINLMinneapolisInternational FallsMNMN
30311152014-03-03T11:15:00.000+000017221MSPINLMinneapolisInternational FallsMNMN
30411152014-03-04T11:15:00.000+00000221MSPINLMinneapolisInternational FallsMNMN
30511152014-03-05T11:15:00.000+0000-7221MSPINLMinneapolisInternational FallsMNMN
30611152014-03-06T11:15:00.000+0000-8221MSPINLMinneapolisInternational FallsMNMN
30711152014-03-07T11:15:00.000+0000-10221MSPINLMinneapolisInternational FallsMNMN
30820002014-03-08T20:00:00.000+0000-11221MSPINLMinneapolisInternational FallsMNMN
30920002014-03-09T20:00:00.000+0000-9221MSPINLMinneapolisInternational FallsMNMN
31011152014-03-10T11:15:00.000+0000-10221MSPINLMinneapolisInternational FallsMNMN
31111152014-03-11T11:15:00.000+0000-8221MSPINLMinneapolisInternational FallsMNMN
31211152014-03-12T11:15:00.000+0000-6221MSPINLMinneapolisInternational FallsMNMN
31311152014-03-13T11:15:00.000+0000-8221MSPINLMinneapolisInternational FallsMNMN
31411152014-03-14T11:15:00.000+0000-5221MSPINLMinneapolisInternational FallsMNMN
31520002014-03-15T20:00:00.000+0000-11221MSPINLMinneapolisInternational FallsMNMN
31620002014-03-16T20:00:00.000+0000-10221MSPINLMinneapolisInternational FallsMNMN
31711152014-03-17T11:15:00.000+000025221MSPINLMinneapolisInternational FallsMNMN
31811152014-03-18T11:15:00.000+00002221MSPINLMinneapolisInternational FallsMNMN
31911152014-03-19T11:15:00.000+0000-5221MSPINLMinneapolisInternational FallsMNMN
32011152014-03-20T11:15:00.000+0000-6221MSPINLMinneapolisInternational FallsMNMN
32111152014-03-21T11:15:00.000+00000221MSPINLMinneapolisInternational FallsMNMN
32220002014-03-22T20:00:00.000+0000-10221MSPINLMinneapolisInternational FallsMNMN
32320002014-03-23T20:00:00.000+0000-9221MSPINLMinneapolisInternational FallsMNMN
32411152014-03-24T11:15:00.000+0000-9221MSPINLMinneapolisInternational FallsMNMN
32511152014-03-25T11:15:00.000+0000-4221MSPINLMinneapolisInternational FallsMNMN
32611152014-03-26T11:15:00.000+0000-5221MSPINLMinneapolisInternational FallsMNMN
32711152014-03-27T11:15:00.000+00009221MSPINLMinneapolisInternational FallsMNMN
32811152014-03-28T11:15:00.000+0000-7221MSPINLMinneapolisInternational FallsMNMN
32920002014-03-29T20:00:00.000+0000-19221MSPINLMinneapolisInternational FallsMNMN
33020002014-03-30T20:00:00.000+0000-10221MSPINLMinneapolisInternational FallsMNMN
33111152014-03-31T11:15:00.000+0000-8221MSPINLMinneapolisInternational FallsMNMN
30212182014-03-02T12:18:00.000+00002265IAHMSYHoustonNew OrleansTXLA
30216462014-03-02T16:46:00.000+0000-6265IAHMSYHoustonNew OrleansTXLA
30312152014-03-03T12:15:00.000+0000105265IAHMSYHoustonNew OrleansTXLA
30316462014-03-03T16:46:00.000+000058265IAHMSYHoustonNew OrleansTXLA
30317382014-03-03T17:38:00.000+00000265IAHMSYHoustonNew OrleansTXLA
30417382014-03-04T17:38:00.000+000071265IAHMSYHoustonNew OrleansTXLA
30416462014-03-04T16:46:00.000+000014265IAHMSYHoustonNew OrleansTXLA
30516462014-03-05T16:46:00.000+0000-4265IAHMSYHoustonNew OrleansTXLA
30517382014-03-05T17:38:00.000+00004265IAHMSYHoustonNew OrleansTXLA
30512182014-03-05T12:18:00.000+0000-4265IAHMSYHoustonNew OrleansTXLA
30612122014-03-06T12:12:00.000+000011265IAHMSYHoustonNew OrleansTXLA

Showing the first 1000 rows.

Building the Graph

Now that we've imported our data, we're going to need to build our graph. To do so we're going to do two things. We are going to build the structure of the vertices (or nodes) and we're going to build the structure of the edges. What's awesome about GraphFrames is that this process is incredibly simple.

  • Rename IATA airport code to id in the Vertices Table
  • Start and End airports to src and dst for the Edges Table (flights)

These are required naming conventions for vertices and edges in GraphFrames.

WARNING: If the graphframes package, required in the cell below, is not installed, follow the instructions here.

// Note, ensure you have already installed the GraphFrames spack-package
import org.apache.spark.sql.functions._
import org.graphframes._

// Create Vertices (airports) and Edges (flights)
val tripVertices = airports.withColumnRenamed("IATA", "id").distinct()
val tripEdges = departureDelays_geo.select("tripid", "delay", "src", "dst", "city_dst", "state_dst")

// Cache Vertices and Edges
tripEdges.cache()
tripVertices.cache()
import org.apache.spark.sql.functions._ import org.graphframes._ tripVertices: org.apache.spark.sql.Dataset[org.apache.spark.sql.Row] = [id: string, City: string ... 2 more fields] tripEdges: org.apache.spark.sql.DataFrame = [tripid: int, delay: int ... 4 more fields] res92: tripVertices.type = [id: string, City: string ... 2 more fields]
// Vertices
// The vertices of our graph are the airports
display(tripVertices)
FATFresnoCAUSA
CMHColumbusOHUSA
PHXPhoenixAZUSA
PAHPaducahKYUSA
COSColorado SpringsCOUSA
MYRMyrtle BeachSCUSA
RNORenoNVUSA
SRQSarasotaFLUSA
PSCPascoWAUSA
CAEColumbiaSCUSA
VLDValdostaGAUSA
BPTBeaumontTXUSA
LAXLos AngelesCAUSA
DAYDaytonOHUSA
AVPWilkes-BarrePAUSA
MFRMedfordORUSA
JFKNew YorkNYUSA
LASLas VegasNVUSA
BNANashvilleTNUSA
CLTCharlotteNCUSA
BDLHartfordCTUSA
ILGWilmingtonDEUSA
ATWAppletonWIUSA
RHIRhinelanderWIUSA
ACTWacoTXUSA
PWMPortlandMEUSA
SJTSan AngeloTXUSA
GRBGreen BayWIUSA
APNAlpenaMIUSA
MSYNew OrleansLAUSA
CAKAkronOHUSA
LANLansingMIUSA
FLLFort LauderdaleFLUSA
TPATampaFLUSA
SATSan AntonioTXUSA
CODCodyWYUSA
MODModestoCAUSA
GTRColumbusMSUSA
RDDReddingCAUSA
BTVBurlingtonVTUSA
HLNHelenaMTUSA
FWAFort WayneINUSA
IMTIron MountainMIUSA
CPRCasperWYUSA
BZNBozemanMTUSA
DTWDetroitMIUSA
SBNSouth BendINUSA
SPSWichita FallsTXUSA
BFLBakersfieldCAUSA
TVCTraverse CityMIUSA
CLEClevelandOHUSA
ABRAberdeenSDUSA
HOBHobbsNMUSA
CHSCharlestonSCUSA
GUCGunnisonCOUSA
INDIndianapolisINUSA
SDFLouisvilleKYUSA
RSWFort MyersFLUSA
SANSan DiegoCAUSA
TULTulsaOKUSA
BOSBostonMAUSA
AGSAugustaGAUSA
MOBMobileALUSA
TUSTucsonAZUSA
KTNKetchikanAKUSA
BTRBaton RougeLAUSA
PNSPensacolaFLUSA
ABQAlbuquerqueNMUSA
MAFMidlandTXUSA
JNUJuneauAKUSA
LGANew YorkNYUSA
DALDallasTXUSA
FARFargoNDUSA
MTJMontroseCOUSA
RICRichmondVAUSA
AMAAmarilloTXUSA
ROCRochesterNYUSA
YAKYakutatAKUSA
SHVShreveportLAUSA
CRPCorpus ChristiTXUSA
ALOWaterlooIAUSA
DRODurangoCOUSA
CSGColumbusGAUSA
GSOGreensboroNCUSA
FNTFlintMIUSA
LWSLewistonIDUSA
TOLToledoOHUSA
GTFGreat FallsMTUSA
RKSRock SpringsWYUSA
MKEMilwaukeeWIUSA
STLSt. LouisMOUSA
MHTManchesterNHUSA
CRWCharlestonWVUSA
SLCSalt Lake CityUTUSA
ACVEurekaCAUSA
DFWDallasTXUSA
OMENomeAKUSA
ORFNorfolkVAUSA
RDURaleighNCUSA
ROARoanokeVAUSA
// Edges
// The edges of our graph are the flights between airports
display(tripEdges)
1011111-5MSPINLInternational FallsMN
10211117MSPINLInternational FallsMN
10311110MSPINLInternational FallsMN
10419250MSPINLInternational FallsMN
106111533MSPINLInternational FallsMN
107111523MSPINLInternational FallsMN
1081115-9MSPINLInternational FallsMN
109111511MSPINLInternational FallsMN
1101115-3MSPINLInternational FallsMN
1112015-7MSPINLInternational FallsMN
1121925-5MSPINLInternational FallsMN
1131115-3MSPINLInternational FallsMN
1141115-6MSPINLInternational FallsMN
1151115-7MSPINLInternational FallsMN
1161115-3MSPINLInternational FallsMN
11711154MSPINLInternational FallsMN
1182015-5MSPINLInternational FallsMN
1191925-7MSPINLInternational FallsMN
1201115-6MSPINLInternational FallsMN
12111150MSPINLInternational FallsMN
1221115-4MSPINLInternational FallsMN
1231115-4MSPINLInternational FallsMN
1241115-3MSPINLInternational FallsMN
1252015-12MSPINLInternational FallsMN
1261925-5MSPINLInternational FallsMN
12711150MSPINLInternational FallsMN
1281115-8MSPINLInternational FallsMN
1291115-2MSPINLInternational FallsMN
13011150MSPINLInternational FallsMN
1311115-3MSPINLInternational FallsMN
2012015-4MSPINLInternational FallsMN
20220150MSPINLInternational FallsMN
2031115-7MSPINLInternational FallsMN
2041115-6MSPINLInternational FallsMN
2051115-4MSPINLInternational FallsMN
2061115-2MSPINLInternational FallsMN
2071115-15MSPINLInternational FallsMN
2082015-4MSPINLInternational FallsMN
20919251MSPINLInternational FallsMN
2101115-3MSPINLInternational FallsMN
2111115-7MSPINLInternational FallsMN
2121115-2MSPINLInternational FallsMN
2131115-3MSPINLInternational FallsMN
2141115-11MSPINLInternational FallsMN
215201516MSPINLInternational FallsMN
2161925169MSPINLInternational FallsMN
217111527MSPINLInternational FallsMN
218111596MSPINLInternational FallsMN
2191115-9MSPINLInternational FallsMN
2201115-6MSPINLInternational FallsMN
2211115-4MSPINLInternational FallsMN
2222015-4MSPINLInternational FallsMN
2231925-3MSPINLInternational FallsMN
2241115-2MSPINLInternational FallsMN
2251115-6MSPINLInternational FallsMN
2261115-8MSPINLInternational FallsMN
2271115-8MSPINLInternational FallsMN
22811155MSPINLInternational FallsMN
3012015-4MSPINLInternational FallsMN
30220000MSPINLInternational FallsMN
303111517MSPINLInternational FallsMN
30411150MSPINLInternational FallsMN
3051115-7MSPINLInternational FallsMN
3061115-8MSPINLInternational FallsMN
3071115-10MSPINLInternational FallsMN
3082000-11MSPINLInternational FallsMN
3092000-9MSPINLInternational FallsMN
3101115-10MSPINLInternational FallsMN
3111115-8MSPINLInternational FallsMN
3121115-6MSPINLInternational FallsMN
3131115-8MSPINLInternational FallsMN
3141115-5MSPINLInternational FallsMN
3152000-11MSPINLInternational FallsMN
3162000-10MSPINLInternational FallsMN
317111525MSPINLInternational FallsMN
31811152MSPINLInternational FallsMN
3191115-5MSPINLInternational FallsMN
3201115-6MSPINLInternational FallsMN
32111150MSPINLInternational FallsMN
3222000-10MSPINLInternational FallsMN
3232000-9MSPINLInternational FallsMN
3241115-9MSPINLInternational FallsMN
3251115-4MSPINLInternational FallsMN
3261115-5MSPINLInternational FallsMN
32711159MSPINLInternational FallsMN
3281115-7MSPINLInternational FallsMN
3292000-19MSPINLInternational FallsMN
3302000-10MSPINLInternational FallsMN
3311115-8MSPINLInternational FallsMN
30212182IAHMSYNew OrleansLA
3021646-6IAHMSYNew OrleansLA
3031215105IAHMSYNew OrleansLA
303164658IAHMSYNew OrleansLA
30317380IAHMSYNew OrleansLA
304173871IAHMSYNew OrleansLA
304164614IAHMSYNew OrleansLA
3051646-4IAHMSYNew OrleansLA
30517384IAHMSYNew OrleansLA
3051218-4IAHMSYNew OrleansLA
306121211IAHMSYNew OrleansLA

Showing the first 1000 rows.

// Build `tripGraph` GraphFrame
// This GraphFrame builds up on the vertices and edges based on our trips (flights)
val tripGraph = GraphFrame(tripVertices, tripEdges)
println(tripGraph)

// Build `tripGraphPrime` GraphFrame
// This graphframe contains a smaller subset of data to make it easier to display motifs and subgraphs (below)
val tripEdgesPrime = departureDelays_geo.select("tripid", "delay", "src", "dst")
val tripGraphPrime = GraphFrame(tripVertices, tripEdgesPrime)
GraphFrame(v:[id: string, City: string ... 2 more fields], e:[src: string, dst: string ... 4 more fields]) tripGraph: org.graphframes.GraphFrame = GraphFrame(v:[id: string, City: string ... 2 more fields], e:[src: string, dst: string ... 4 more fields]) tripEdgesPrime: org.apache.spark.sql.DataFrame = [tripid: int, delay: int ... 2 more fields] tripGraphPrime: org.graphframes.GraphFrame = GraphFrame(v:[id: string, City: string ... 2 more fields], e:[src: string, dst: string ... 2 more fields])

Simple Queries

Let's start with a set of simple graph queries to understand flight performance and departure delays

Determine the number of airports and trips

println(s"Airports: ${tripGraph.vertices.count()}")
println(s"Trips: ${tripGraph.edges.count()}")
Airports: 279 Trips: 1361141

Determining the longest delay in this dataset

// Finding the longest Delay
val longestDelay = tripGraph.edges.groupBy().max("delay")
display(longestDelay)
1642
1642.0/60.0
res100: Double = 27.366666666666667

Determining the number of delayed vs. on-time / early flights

// Determining number of on-time / early flights vs. delayed flights
println(s"On-time / Early Flights: ${tripGraph.edges.filter("delay <= 0").count()}")
println(s"Delayed Flights: ${tripGraph.edges.filter("delay > 0").count()}")
On-time / Early Flights: 780469 Delayed Flights: 580672

What flights departing SFO are most likely to have significant delays

Note, delay can be <= 0 meaning the flight left on time or early

//tripGraph.createOrReplaceTempView("tripgraph")
val sfoDelayedTrips = tripGraph.edges.
  filter("src = 'SFO' and delay > 0").
  groupBy("src", "dst").
  avg("delay").
  sort(desc("avg(delay)"))
sfoDelayedTrips: org.apache.spark.sql.Dataset[org.apache.spark.sql.Row] = [src: string, dst: string ... 1 more field]
display(sfoDelayedTrips)
SFOOKC59.073170731707314
SFOJAC57.13333333333333
SFOCOS53.976190476190474
SFOOTH48.09090909090909
SFOSAT47.625
SFOMOD46.80952380952381
SFOSUN46.723404255319146
SFOCIC46.72164948453608
SFOABQ44.8125
SFOASE44.285714285714285
SFOPIT43.875
SFOMIA43.81730769230769
SFOFAT43.23972602739726
SFOMFR43.11848341232228
SFOSBP43.09770114942529
SFOMSP42.766917293233085
SFOBOI42.65482233502538
SFORDM41.98823529411764
SFOAUS41.690677966101696
SFOSLC41.407272727272726
SFOJFK41.01379310344828
SFOPSP40.909909909909906
SFOPHX40.67272727272727
SFOMRY40.61764705882353
SFOACV40.3728813559322
SFOLAS40.107602339181284
SFOTUS39.853658536585364
SFOSAN38.97361809045226
SFOSBA38.758620689655174
SFOBFL38.51136363636363
SFORDU38.170731707317074
SFOSTL38.13513513513514
SFOIND38.114285714285714
SFOEUG37.573913043478264
SFORNO36.81372549019608
SFOBUR36.75675675675676
SFOLGB36.752941176470586
SFOHNL36.25367647058823
SFOLAX36.165543071161046
SFORDD36.11009174311926
SFOMSY35.421052631578945
SFOSMF34.936
SFOMDW34.824742268041234
SFOFLL34.76842105263158
SFOSEA34.68854961832061
SFOMCI34.68571428571428
SFODFW34.36642599277978
SFOOGG34.171875
SFOPDX34.14430894308943
SFOORD33.991130820399114
SFOLIH32.93023255813954
SFODEN32.861491628614914
SFOPSC32.604651162790695
SFOPHL32.440677966101696
SFOBWI31.70212765957447
SFOONT31.49079754601227
SFOSNA31.18426103646833
SFOMCO31.03488372093023
SFOMKE31.03448275862069
SFOCLE30.979591836734695
SFOEWR30.354285714285716
SFOBOS29.623471882640587
SFOLMT29.233333333333334
SFODTW28.34722222222222
SFOIAH28.322105263157894
SFOCVG27.03125
SFOATL26.84860557768924
SFOIAD26.125964010282775
SFOANC25.5
SFOBZN23.964285714285715
SFOCLT22.636363636363637
SFODCA21.896103896103895

What destinations tend to have delays

// After displaying tripDelays, use Plot Options to set `state_dst` as a Key.
val tripDelays = tripGraph.edges.filter($"delay" > 0)
display(tripDelays)
+−Following states were not found: N/A0-1010-2020-3030-4040-5050-60

What destinations tend to have significant delays departing from SEA

// States with the longest cumulative delays (with individual delays > 100 minutes) (origin: Seattle)
display(tripGraph.edges.filter($"src" === "SEA" && $"delay" > 100))
+−Following states were not found: N/A0-50005000-1000010000-1500015000-20000

Vertex Degrees

  • inDegrees: Incoming connections to the airport
  • outDegrees: Outgoing connections from the airport
  • degrees: Total connections to and from the airport

Reviewing the various properties of the property graph to understand the incoming and outgoing connections between airports.

// Degrees
// The number of degrees - the number of incoming and outgoing connections - for various airports within this sample dataset
display(tripGraph.degrees.sort($"degree".desc).limit(20))
0.0020k40k60k80k100k120k140k160k180k200kATLDFWORDLAXDENIAHPHXSFOLASCLTEWRMCOLGASLCBOSDTWMSPSEAJFKBWITOOLTIPiddegree

City / Flight Relationships through Motif Finding

To more easily understand the complex relationship of city airports and their flights with each other, we can use motifs to find patterns of airports (i.e. vertices) connected by flights (i.e. edges). The result is a DataFrame in which the column names are given by the motif keys.

What delays might we blame on SFO

/*
Using tripGraphPrime to more easily display 
- The associated edge (ab, bc) relationships 
- With the different the city / airports (a, b, c) where SFO is the connecting city (b)
- Ensuring that flight ab (i.e. the flight to SFO) occured before flight bc (i.e. flight leaving SFO)
- Note, TripID was generated based on time in the format of MMDDHHMM converted to int
- Therefore bc.tripid < ab.tripid + 10000 means the second flight (bc) occured within approx a day of the first flight (ab)
Note: In reality, we would need to be more careful to link trips ab and bc.
*/
val motifs = tripGraphPrime.
  find("(a)-[ab]->(b); (b)-[bc]->(c)").
  filter("(b.id = 'SFO') and (ab.delay > 500 or bc.delay > 500) and bc.tripid > ab.tripid and bc.tripid < ab.tripid + 10000")

display(motifs)
{"id":"HNL","City":"Honolulu, Oahu","State":"HI","Country":"USA"}{"tripid":2040725,"delay":622,"src":"HNL","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2042232,"delay":-3,"src":"SFO","dst":"EUG"}{"id":"EUG","City":"Eugene","State":"OR","Country":"USA"}
{"id":"HNL","City":"Honolulu, Oahu","State":"HI","Country":"USA"}{"tripid":2040725,"delay":622,"src":"HNL","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2041310,"delay":80,"src":"SFO","dst":"EUG"}{"id":"EUG","City":"Eugene","State":"OR","Country":"USA"}
{"id":"HNL","City":"Honolulu, Oahu","State":"HI","Country":"USA"}{"tripid":2040725,"delay":622,"src":"HNL","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2041457,"delay":-3,"src":"SFO","dst":"EUG"}{"id":"EUG","City":"Eugene","State":"OR","Country":"USA"}
{"id":"HNL","City":"Honolulu, Oahu","State":"HI","Country":"USA"}{"tripid":2040725,"delay":622,"src":"HNL","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2040831,"delay":-9,"src":"SFO","dst":"EUG"}{"id":"EUG","City":"Eugene","State":"OR","Country":"USA"}
{"id":"HNL","City":"Honolulu, Oahu","State":"HI","Country":"USA"}{"tripid":2040725,"delay":622,"src":"HNL","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2041035,"delay":26,"src":"SFO","dst":"EUG"}{"id":"EUG","City":"Eugene","State":"OR","Country":"USA"}
{"id":"HNL","City":"Honolulu, Oahu","State":"HI","Country":"USA"}{"tripid":2040725,"delay":622,"src":"HNL","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2041915,"delay":5,"src":"SFO","dst":"EUG"}{"id":"EUG","City":"Eugene","State":"OR","Country":"USA"}
{"id":"HNL","City":"Honolulu, Oahu","State":"HI","Country":"USA"}{"tripid":2102155,"delay":724,"src":"HNL","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2102232,"delay":16,"src":"SFO","dst":"EUG"}{"id":"EUG","City":"Eugene","State":"OR","Country":"USA"}
{"id":"HNL","City":"Honolulu, Oahu","State":"HI","Country":"USA"}{"tripid":2102155,"delay":724,"src":"HNL","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2111310,"delay":30,"src":"SFO","dst":"EUG"}{"id":"EUG","City":"Eugene","State":"OR","Country":"USA"}
{"id":"HNL","City":"Honolulu, Oahu","State":"HI","Country":"USA"}{"tripid":2102155,"delay":724,"src":"HNL","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2111457,"delay":-4,"src":"SFO","dst":"EUG"}{"id":"EUG","City":"Eugene","State":"OR","Country":"USA"}
{"id":"HNL","City":"Honolulu, Oahu","State":"HI","Country":"USA"}{"tripid":2102155,"delay":724,"src":"HNL","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2110831,"delay":1,"src":"SFO","dst":"EUG"}{"id":"EUG","City":"Eugene","State":"OR","Country":"USA"}
{"id":"HNL","City":"Honolulu, Oahu","State":"HI","Country":"USA"}{"tripid":2102155,"delay":724,"src":"HNL","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2111035,"delay":58,"src":"SFO","dst":"EUG"}{"id":"EUG","City":"Eugene","State":"OR","Country":"USA"}
{"id":"HNL","City":"Honolulu, Oahu","State":"HI","Country":"USA"}{"tripid":2141405,"delay":586,"src":"HNL","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2141500,"delay":42,"src":"SFO","dst":"EUG"}{"id":"EUG","City":"Eugene","State":"OR","Country":"USA"}
{"id":"HNL","City":"Honolulu, Oahu","State":"HI","Country":"USA"}{"tripid":2141405,"delay":586,"src":"HNL","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2142226,"delay":-3,"src":"SFO","dst":"EUG"}{"id":"EUG","City":"Eugene","State":"OR","Country":"USA"}
{"id":"HNL","City":"Honolulu, Oahu","State":"HI","Country":"USA"}{"tripid":2141405,"delay":586,"src":"HNL","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2142037,"delay":-1,"src":"SFO","dst":"EUG"}{"id":"EUG","City":"Eugene","State":"OR","Country":"USA"}
{"id":"HNL","City":"Honolulu, Oahu","State":"HI","Country":"USA"}{"tripid":2141405,"delay":586,"src":"HNL","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2150838,"delay":-4,"src":"SFO","dst":"EUG"}{"id":"EUG","City":"Eugene","State":"OR","Country":"USA"}
{"id":"HNL","City":"Honolulu, Oahu","State":"HI","Country":"USA"}{"tripid":2141405,"delay":586,"src":"HNL","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2151040,"delay":-1,"src":"SFO","dst":"EUG"}{"id":"EUG","City":"Eugene","State":"OR","Country":"USA"}
{"id":"HNL","City":"Honolulu, Oahu","State":"HI","Country":"USA"}{"tripid":2141405,"delay":586,"src":"HNL","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2151250,"delay":7,"src":"SFO","dst":"EUG"}{"id":"EUG","City":"Eugene","State":"OR","Country":"USA"}
{"id":"MCI","City":"Kansas City","State":"MO","Country":"USA"}{"tripid":3160600,"delay":637,"src":"MCI","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":3162226,"delay":2,"src":"SFO","dst":"EUG"}{"id":"EUG","City":"Eugene","State":"OR","Country":"USA"}
{"id":"MCI","City":"Kansas City","State":"MO","Country":"USA"}{"tripid":3160600,"delay":637,"src":"MCI","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":3161459,"delay":-2,"src":"SFO","dst":"EUG"}{"id":"EUG","City":"Eugene","State":"OR","Country":"USA"}
{"id":"MCI","City":"Kansas City","State":"MO","Country":"USA"}{"tripid":3160600,"delay":637,"src":"MCI","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":3160823,"delay":12,"src":"SFO","dst":"EUG"}{"id":"EUG","City":"Eugene","State":"OR","Country":"USA"}
{"id":"MCI","City":"Kansas City","State":"MO","Country":"USA"}{"tripid":3160600,"delay":637,"src":"MCI","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":3161038,"delay":10,"src":"SFO","dst":"EUG"}{"id":"EUG","City":"Eugene","State":"OR","Country":"USA"}
{"id":"MCI","City":"Kansas City","State":"MO","Country":"USA"}{"tripid":3160600,"delay":637,"src":"MCI","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":3161313,"delay":16,"src":"SFO","dst":"EUG"}{"id":"EUG","City":"Eugene","State":"OR","Country":"USA"}
{"id":"MCI","City":"Kansas City","State":"MO","Country":"USA"}{"tripid":3160600,"delay":637,"src":"MCI","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":3162101,"delay":19,"src":"SFO","dst":"EUG"}{"id":"EUG","City":"Eugene","State":"OR","Country":"USA"}
{"id":"MDW","City":"Chicago","State":"IL","Country":"USA"}{"tripid":1020840,"delay":509,"src":"MDW","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":1021421,"delay":59,"src":"SFO","dst":"EUG"}{"id":"EUG","City":"Eugene","State":"OR","Country":"USA"}
{"id":"MDW","City":"Chicago","State":"IL","Country":"USA"}{"tripid":1020840,"delay":509,"src":"MDW","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":1021657,"delay":5,"src":"SFO","dst":"EUG"}{"id":"EUG","City":"Eugene","State":"OR","Country":"USA"}
{"id":"MDW","City":"Chicago","State":"IL","Country":"USA"}{"tripid":1020840,"delay":509,"src":"MDW","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":1021035,"delay":0,"src":"SFO","dst":"EUG"}{"id":"EUG","City":"Eugene","State":"OR","Country":"USA"}
{"id":"MDW","City":"Chicago","State":"IL","Country":"USA"}{"tripid":1020840,"delay":509,"src":"MDW","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":1021310,"delay":-3,"src":"SFO","dst":"EUG"}{"id":"EUG","City":"Eugene","State":"OR","Country":"USA"}
{"id":"MDW","City":"Chicago","State":"IL","Country":"USA"}{"tripid":1020840,"delay":509,"src":"MDW","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":1022238,"delay":19,"src":"SFO","dst":"EUG"}{"id":"EUG","City":"Eugene","State":"OR","Country":"USA"}
{"id":"MDW","City":"Chicago","State":"IL","Country":"USA"}{"tripid":1020840,"delay":509,"src":"MDW","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":1022050,"delay":10,"src":"SFO","dst":"EUG"}{"id":"EUG","City":"Eugene","State":"OR","Country":"USA"}
{"id":"MDW","City":"Chicago","State":"IL","Country":"USA"}{"tripid":1020840,"delay":509,"src":"MDW","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":1030817,"delay":9,"src":"SFO","dst":"EUG"}{"id":"EUG","City":"Eugene","State":"OR","Country":"USA"}
{"id":"HNL","City":"Honolulu, Oahu","State":"HI","Country":"USA"}{"tripid":2040725,"delay":622,"src":"HNL","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2041401,"delay":0,"src":"SFO","dst":"DCA"}{"id":"DCA","City":"Washington DC","State":null,"Country":"USA"}
{"id":"HNL","City":"Honolulu, Oahu","State":"HI","Country":"USA"}{"tripid":2102155,"delay":724,"src":"HNL","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2111401,"delay":-3,"src":"SFO","dst":"DCA"}{"id":"DCA","City":"Washington DC","State":null,"Country":"USA"}
{"id":"HNL","City":"Honolulu, Oahu","State":"HI","Country":"USA"}{"tripid":2141405,"delay":586,"src":"HNL","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2151353,"delay":1,"src":"SFO","dst":"DCA"}{"id":"DCA","City":"Washington DC","State":null,"Country":"USA"}
{"id":"HNL","City":"Honolulu, Oahu","State":"HI","Country":"USA"}{"tripid":2040725,"delay":622,"src":"HNL","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2040800,"delay":-3,"src":"SFO","dst":"DCA"}{"id":"DCA","City":"Washington DC","State":null,"Country":"USA"}
{"id":"HNL","City":"Honolulu, Oahu","State":"HI","Country":"USA"}{"tripid":2102155,"delay":724,"src":"HNL","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2110800,"delay":-4,"src":"SFO","dst":"DCA"}{"id":"DCA","City":"Washington DC","State":null,"Country":"USA"}
{"id":"HNL","City":"Honolulu, Oahu","State":"HI","Country":"USA"}{"tripid":2141405,"delay":586,"src":"HNL","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2150800,"delay":-1,"src":"SFO","dst":"DCA"}{"id":"DCA","City":"Washington DC","State":null,"Country":"USA"}
{"id":"MCI","City":"Kansas City","State":"MO","Country":"USA"}{"tripid":3160600,"delay":637,"src":"MCI","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":3161353,"delay":4,"src":"SFO","dst":"DCA"}{"id":"DCA","City":"Washington DC","State":null,"Country":"USA"}
{"id":"MCI","City":"Kansas City","State":"MO","Country":"USA"}{"tripid":3160600,"delay":637,"src":"MCI","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":3160800,"delay":-3,"src":"SFO","dst":"DCA"}{"id":"DCA","City":"Washington DC","State":null,"Country":"USA"}
{"id":"MDW","City":"Chicago","State":"IL","Country":"USA"}{"tripid":1020840,"delay":509,"src":"MDW","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":1021352,"delay":-5,"src":"SFO","dst":"DCA"}{"id":"DCA","City":"Washington DC","State":null,"Country":"USA"}
{"id":"MDW","City":"Chicago","State":"IL","Country":"USA"}{"tripid":1020840,"delay":509,"src":"MDW","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":1030800,"delay":0,"src":"SFO","dst":"DCA"}{"id":"DCA","City":"Washington DC","State":null,"Country":"USA"}
{"id":"HNL","City":"Honolulu, Oahu","State":"HI","Country":"USA"}{"tripid":2040725,"delay":622,"src":"HNL","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2041223,"delay":-3,"src":"SFO","dst":"RDM"}{"id":"RDM","City":"Redmond","State":"OR","Country":"USA"}
{"id":"HNL","City":"Honolulu, Oahu","State":"HI","Country":"USA"}{"tripid":2040725,"delay":622,"src":"HNL","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2042227,"delay":-3,"src":"SFO","dst":"RDM"}{"id":"RDM","City":"Redmond","State":"OR","Country":"USA"}
{"id":"HNL","City":"Honolulu, Oahu","State":"HI","Country":"USA"}{"tripid":2102155,"delay":724,"src":"HNL","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2102227,"delay":47,"src":"SFO","dst":"RDM"}{"id":"RDM","City":"Redmond","State":"OR","Country":"USA"}
{"id":"HNL","City":"Honolulu, Oahu","State":"HI","Country":"USA"}{"tripid":2102155,"delay":724,"src":"HNL","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2111223,"delay":59,"src":"SFO","dst":"RDM"}{"id":"RDM","City":"Redmond","State":"OR","Country":"USA"}
{"id":"HNL","City":"Honolulu, Oahu","State":"HI","Country":"USA"}{"tripid":2141405,"delay":586,"src":"HNL","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2142227,"delay":0,"src":"SFO","dst":"RDM"}{"id":"RDM","City":"Redmond","State":"OR","Country":"USA"}
{"id":"HNL","City":"Honolulu, Oahu","State":"HI","Country":"USA"}{"tripid":2141405,"delay":586,"src":"HNL","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2151222,"delay":-4,"src":"SFO","dst":"RDM"}{"id":"RDM","City":"Redmond","State":"OR","Country":"USA"}
{"id":"MCI","City":"Kansas City","State":"MO","Country":"USA"}{"tripid":3160600,"delay":637,"src":"MCI","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":3162227,"delay":-8,"src":"SFO","dst":"RDM"}{"id":"RDM","City":"Redmond","State":"OR","Country":"USA"}
{"id":"MCI","City":"Kansas City","State":"MO","Country":"USA"}{"tripid":3160600,"delay":637,"src":"MCI","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":3161221,"delay":-3,"src":"SFO","dst":"RDM"}{"id":"RDM","City":"Redmond","State":"OR","Country":"USA"}
{"id":"MDW","City":"Chicago","State":"IL","Country":"USA"}{"tripid":1020840,"delay":509,"src":"MDW","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":1022228,"delay":-5,"src":"SFO","dst":"RDM"}{"id":"RDM","City":"Redmond","State":"OR","Country":"USA"}
{"id":"MDW","City":"Chicago","State":"IL","Country":"USA"}{"tripid":1020840,"delay":509,"src":"MDW","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":1021715,"delay":40,"src":"SFO","dst":"RDM"}{"id":"RDM","City":"Redmond","State":"OR","Country":"USA"}
{"id":"MDW","City":"Chicago","State":"IL","Country":"USA"}{"tripid":1020840,"delay":509,"src":"MDW","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":1021225,"delay":30,"src":"SFO","dst":"RDM"}{"id":"RDM","City":"Redmond","State":"OR","Country":"USA"}
{"id":"HNL","City":"Honolulu, Oahu","State":"HI","Country":"USA"}{"tripid":2040725,"delay":622,"src":"HNL","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2040819,"delay":-4,"src":"SFO","dst":"MOD"}{"id":"MOD","City":"Modesto","State":"CA","Country":"USA"}
{"id":"HNL","City":"Honolulu, Oahu","State":"HI","Country":"USA"}{"tripid":2040725,"delay":622,"src":"HNL","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2041514,"delay":-6,"src":"SFO","dst":"MOD"}{"id":"MOD","City":"Modesto","State":"CA","Country":"USA"}
{"id":"HNL","City":"Honolulu, Oahu","State":"HI","Country":"USA"}{"tripid":2040725,"delay":622,"src":"HNL","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2042156,"delay":-8,"src":"SFO","dst":"MOD"}{"id":"MOD","City":"Modesto","State":"CA","Country":"USA"}
{"id":"HNL","City":"Honolulu, Oahu","State":"HI","Country":"USA"}{"tripid":2102155,"delay":724,"src":"HNL","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2102156,"delay":-4,"src":"SFO","dst":"MOD"}{"id":"MOD","City":"Modesto","State":"CA","Country":"USA"}
{"id":"HNL","City":"Honolulu, Oahu","State":"HI","Country":"USA"}{"tripid":2102155,"delay":724,"src":"HNL","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2110819,"delay":9,"src":"SFO","dst":"MOD"}{"id":"MOD","City":"Modesto","State":"CA","Country":"USA"}
{"id":"HNL","City":"Honolulu, Oahu","State":"HI","Country":"USA"}{"tripid":2102155,"delay":724,"src":"HNL","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2111514,"delay":15,"src":"SFO","dst":"MOD"}{"id":"MOD","City":"Modesto","State":"CA","Country":"USA"}
{"id":"HNL","City":"Honolulu, Oahu","State":"HI","Country":"USA"}{"tripid":2141405,"delay":586,"src":"HNL","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2141420,"delay":127,"src":"SFO","dst":"MOD"}{"id":"MOD","City":"Modesto","State":"CA","Country":"USA"}
{"id":"HNL","City":"Honolulu, Oahu","State":"HI","Country":"USA"}{"tripid":2141405,"delay":586,"src":"HNL","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2142155,"delay":128,"src":"SFO","dst":"MOD"}{"id":"MOD","City":"Modesto","State":"CA","Country":"USA"}
{"id":"HNL","City":"Honolulu, Oahu","State":"HI","Country":"USA"}{"tripid":2141405,"delay":586,"src":"HNL","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2151000,"delay":-7,"src":"SFO","dst":"MOD"}{"id":"MOD","City":"Modesto","State":"CA","Country":"USA"}
{"id":"MCI","City":"Kansas City","State":"MO","Country":"USA"}{"tripid":3160600,"delay":637,"src":"MCI","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":3161000,"delay":-5,"src":"SFO","dst":"MOD"}{"id":"MOD","City":"Modesto","State":"CA","Country":"USA"}
{"id":"MCI","City":"Kansas City","State":"MO","Country":"USA"}{"tripid":3160600,"delay":637,"src":"MCI","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":3161415,"delay":-10,"src":"SFO","dst":"MOD"}{"id":"MOD","City":"Modesto","State":"CA","Country":"USA"}
{"id":"MCI","City":"Kansas City","State":"MO","Country":"USA"}{"tripid":3160600,"delay":637,"src":"MCI","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":3162156,"delay":-3,"src":"SFO","dst":"MOD"}{"id":"MOD","City":"Modesto","State":"CA","Country":"USA"}
{"id":"MDW","City":"Chicago","State":"IL","Country":"USA"}{"tripid":1020840,"delay":509,"src":"MDW","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":1021509,"delay":-6,"src":"SFO","dst":"MOD"}{"id":"MOD","City":"Modesto","State":"CA","Country":"USA"}
{"id":"MDW","City":"Chicago","State":"IL","Country":"USA"}{"tripid":1020840,"delay":509,"src":"MDW","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":1022156,"delay":-10,"src":"SFO","dst":"MOD"}{"id":"MOD","City":"Modesto","State":"CA","Country":"USA"}
{"id":"MDW","City":"Chicago","State":"IL","Country":"USA"}{"tripid":1020840,"delay":509,"src":"MDW","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":1030815,"delay":-4,"src":"SFO","dst":"MOD"}{"id":"MOD","City":"Modesto","State":"CA","Country":"USA"}
{"id":"HNL","City":"Honolulu, Oahu","State":"HI","Country":"USA"}{"tripid":2040725,"delay":622,"src":"HNL","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2040901,"delay":20,"src":"SFO","dst":"LIH"}{"id":"LIH","City":"Lihue, Kauai","State":"HI","Country":"USA"}
{"id":"HNL","City":"Honolulu, Oahu","State":"HI","Country":"USA"}{"tripid":2102155,"delay":724,"src":"HNL","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2110901,"delay":-4,"src":"SFO","dst":"LIH"}{"id":"LIH","City":"Lihue, Kauai","State":"HI","Country":"USA"}
{"id":"HNL","City":"Honolulu, Oahu","State":"HI","Country":"USA"}{"tripid":2141405,"delay":586,"src":"HNL","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2150935,"delay":-4,"src":"SFO","dst":"LIH"}{"id":"LIH","City":"Lihue, Kauai","State":"HI","Country":"USA"}
{"id":"MCI","City":"Kansas City","State":"MO","Country":"USA"}{"tripid":3160600,"delay":637,"src":"MCI","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":3160919,"delay":196,"src":"SFO","dst":"LIH"}{"id":"LIH","City":"Lihue, Kauai","State":"HI","Country":"USA"}
{"id":"MDW","City":"Chicago","State":"IL","Country":"USA"}{"tripid":1020840,"delay":509,"src":"MDW","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":1020928,"delay":173,"src":"SFO","dst":"LIH"}{"id":"LIH","City":"Lihue, Kauai","State":"HI","Country":"USA"}
{"id":"HNL","City":"Honolulu, Oahu","State":"HI","Country":"USA"}{"tripid":2040725,"delay":622,"src":"HNL","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2041623,"delay":0,"src":"SFO","dst":"IAH"}{"id":"IAH","City":"Houston","State":"TX","Country":"USA"}
{"id":"HNL","City":"Honolulu, Oahu","State":"HI","Country":"USA"}{"tripid":2040725,"delay":622,"src":"HNL","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2041425,"delay":-3,"src":"SFO","dst":"IAH"}{"id":"IAH","City":"Houston","State":"TX","Country":"USA"}
{"id":"HNL","City":"Honolulu, Oahu","State":"HI","Country":"USA"}{"tripid":2040725,"delay":622,"src":"HNL","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2041043,"delay":-2,"src":"SFO","dst":"IAH"}{"id":"IAH","City":"Houston","State":"TX","Country":"USA"}
{"id":"HNL","City":"Honolulu, Oahu","State":"HI","Country":"USA"}{"tripid":2040725,"delay":622,"src":"HNL","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2041811,"delay":-5,"src":"SFO","dst":"IAH"}{"id":"IAH","City":"Houston","State":"TX","Country":"USA"}
{"id":"HNL","City":"Honolulu, Oahu","State":"HI","Country":"USA"}{"tripid":2040725,"delay":622,"src":"HNL","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2040920,"delay":-3,"src":"SFO","dst":"IAH"}{"id":"IAH","City":"Houston","State":"TX","Country":"USA"}
{"id":"HNL","City":"Honolulu, Oahu","State":"HI","Country":"USA"}{"tripid":2040725,"delay":622,"src":"HNL","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2041220,"delay":-2,"src":"SFO","dst":"IAH"}{"id":"IAH","City":"Houston","State":"TX","Country":"USA"}
{"id":"HNL","City":"Honolulu, Oahu","State":"HI","Country":"USA"}{"tripid":2040725,"delay":622,"src":"HNL","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2050605,"delay":-6,"src":"SFO","dst":"IAH"}{"id":"IAH","City":"Houston","State":"TX","Country":"USA"}
{"id":"HNL","City":"Honolulu, Oahu","State":"HI","Country":"USA"}{"tripid":2040725,"delay":622,"src":"HNL","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2050030,"delay":12,"src":"SFO","dst":"IAH"}{"id":"IAH","City":"Houston","State":"TX","Country":"USA"}
{"id":"HNL","City":"Honolulu, Oahu","State":"HI","Country":"USA"}{"tripid":2102155,"delay":724,"src":"HNL","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2111623,"delay":0,"src":"SFO","dst":"IAH"}{"id":"IAH","City":"Houston","State":"TX","Country":"USA"}
{"id":"HNL","City":"Honolulu, Oahu","State":"HI","Country":"USA"}{"tripid":2102155,"delay":724,"src":"HNL","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2111425,"delay":8,"src":"SFO","dst":"IAH"}{"id":"IAH","City":"Houston","State":"TX","Country":"USA"}
{"id":"HNL","City":"Honolulu, Oahu","State":"HI","Country":"USA"}{"tripid":2102155,"delay":724,"src":"HNL","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2110605,"delay":69,"src":"SFO","dst":"IAH"}{"id":"IAH","City":"Houston","State":"TX","Country":"USA"}
{"id":"HNL","City":"Honolulu, Oahu","State":"HI","Country":"USA"}{"tripid":2102155,"delay":724,"src":"HNL","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2110030,"delay":9,"src":"SFO","dst":"IAH"}{"id":"IAH","City":"Houston","State":"TX","Country":"USA"}
{"id":"HNL","City":"Honolulu, Oahu","State":"HI","Country":"USA"}{"tripid":2102155,"delay":724,"src":"HNL","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2111043,"delay":2,"src":"SFO","dst":"IAH"}{"id":"IAH","City":"Houston","State":"TX","Country":"USA"}
{"id":"HNL","City":"Honolulu, Oahu","State":"HI","Country":"USA"}{"tripid":2102155,"delay":724,"src":"HNL","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2111811,"delay":-3,"src":"SFO","dst":"IAH"}{"id":"IAH","City":"Houston","State":"TX","Country":"USA"}
{"id":"HNL","City":"Honolulu, Oahu","State":"HI","Country":"USA"}{"tripid":2102155,"delay":724,"src":"HNL","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2110920,"delay":-1,"src":"SFO","dst":"IAH"}{"id":"IAH","City":"Houston","State":"TX","Country":"USA"}
{"id":"HNL","City":"Honolulu, Oahu","State":"HI","Country":"USA"}{"tripid":2102155,"delay":724,"src":"HNL","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2111220,"delay":1,"src":"SFO","dst":"IAH"}{"id":"IAH","City":"Houston","State":"TX","Country":"USA"}
{"id":"HNL","City":"Honolulu, Oahu","State":"HI","Country":"USA"}{"tripid":2141405,"delay":586,"src":"HNL","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2141903,"delay":42,"src":"SFO","dst":"IAH"}{"id":"IAH","City":"Houston","State":"TX","Country":"USA"}
{"id":"HNL","City":"Honolulu, Oahu","State":"HI","Country":"USA"}{"tripid":2141405,"delay":586,"src":"HNL","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2141538,"delay":12,"src":"SFO","dst":"IAH"}{"id":"IAH","City":"Houston","State":"TX","Country":"USA"}
{"id":"HNL","City":"Honolulu, Oahu","State":"HI","Country":"USA"}{"tripid":2141405,"delay":586,"src":"HNL","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2151047,"delay":22,"src":"SFO","dst":"IAH"}{"id":"IAH","City":"Houston","State":"TX","Country":"USA"}
{"id":"HNL","City":"Honolulu, Oahu","State":"HI","Country":"USA"}{"tripid":2141405,"delay":586,"src":"HNL","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2150605,"delay":-5,"src":"SFO","dst":"IAH"}{"id":"IAH","City":"Houston","State":"TX","Country":"USA"}
{"id":"HNL","City":"Honolulu, Oahu","State":"HI","Country":"USA"}{"tripid":2141405,"delay":586,"src":"HNL","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2151256,"delay":0,"src":"SFO","dst":"IAH"}{"id":"IAH","City":"Houston","State":"TX","Country":"USA"}
{"id":"HNL","City":"Honolulu, Oahu","State":"HI","Country":"USA"}{"tripid":2141405,"delay":586,"src":"HNL","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2150853,"delay":1,"src":"SFO","dst":"IAH"}{"id":"IAH","City":"Houston","State":"TX","Country":"USA"}
{"id":"HNL","City":"Honolulu, Oahu","State":"HI","Country":"USA"}{"tripid":2141405,"delay":586,"src":"HNL","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2150030,"delay":8,"src":"SFO","dst":"IAH"}{"id":"IAH","City":"Houston","State":"TX","Country":"USA"}
{"id":"HNL","City":"Honolulu, Oahu","State":"HI","Country":"USA"}{"tripid":2141405,"delay":586,"src":"HNL","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2151350,"delay":17,"src":"SFO","dst":"IAH"}{"id":"IAH","City":"Houston","State":"TX","Country":"USA"}
{"id":"MCI","City":"Kansas City","State":"MO","Country":"USA"}{"tripid":3160600,"delay":637,"src":"MCI","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":3161613,"delay":32,"src":"SFO","dst":"IAH"}{"id":"IAH","City":"Houston","State":"TX","Country":"USA"}
{"id":"MCI","City":"Kansas City","State":"MO","Country":"USA"}{"tripid":3160600,"delay":637,"src":"MCI","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":3161039,"delay":-2,"src":"SFO","dst":"IAH"}{"id":"IAH","City":"Houston","State":"TX","Country":"USA"}
{"id":"MCI","City":"Kansas City","State":"MO","Country":"USA"}{"tripid":3160600,"delay":637,"src":"MCI","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":3161154,"delay":20,"src":"SFO","dst":"IAH"}{"id":"IAH","City":"Houston","State":"TX","Country":"USA"}
{"id":"MCI","City":"Kansas City","State":"MO","Country":"USA"}{"tripid":3160600,"delay":637,"src":"MCI","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":3161240,"delay":-7,"src":"SFO","dst":"IAH"}{"id":"IAH","City":"Houston","State":"TX","Country":"USA"}
{"id":"MCI","City":"Kansas City","State":"MO","Country":"USA"}{"tripid":3160600,"delay":637,"src":"MCI","dst":"SFO"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":3160855,"delay":-3,"src":"SFO","dst":"IAH"}{"id":"IAH","City":"Houston","State":"TX","Country":"USA"}

Showing the first 1000 rows.

Determining Airport Ranking using PageRank

There are a large number of flights and connections through these various airports included in this Departure Delay Dataset. Using the pageRank algorithm, Spark iteratively traverses the graph and determines a rough estimate of how important the airport is.

// Determining Airport ranking of importance using `pageRank`
val ranks = tripGraph.pageRank.resetProbability(0.15).maxIter(5).run()
ranks: org.graphframes.GraphFrame = GraphFrame(v:[id: string, City: string ... 3 more fields], e:[src: string, dst: string ... 5 more fields])
display(ranks.vertices.orderBy($"pagerank".desc).limit(20))
0.002.04.06.08.0101214161820ATLDFWORDDENLAXIAHSFOPHXSLCLASSEAEWRMCOCLTDTWMSPLGABOSBWIJFKTOOLTIPidpagerank

BTW, A lot more delicate air-traffic arithmetic is possible for a full month of airplane co-trajectories over the radar range of Atlanta, Georgia!

See for instance:

Most popular flights (single city hops)

Using the tripGraph, we can quickly determine what are the most popular single city hop flights

// Determine the most popular flights (single city hops)
import org.apache.spark.sql.functions._

val topTrips = tripGraph.edges.
  groupBy("src", "dst").
  agg(count("delay").as("trips"))
import org.apache.spark.sql.functions._ topTrips: org.apache.spark.sql.DataFrame = [src: string, dst: string ... 1 more field]
// Show the top 20 most popular flights (single city hops)
display(topTrips.orderBy($"trips".desc).limit(20))
SFOLAX3232
LAXSFO3198
LASLAX3016
LAXLAS2964
JFKLAX2720
LAXJFK2719
ATLLGA2501
LGAATL2500
LAXPHX2394
PHXLAX2387
HNLOGG2380
OGGHNL2379
LAXSAN2215
SANLAX2214
SJCLAX2208
LAXSJC2201
ATLMCO2136
MCOATL2090
SFOJFK2084
JFKSFO2084

Top Transfer Cities

Many airports are used as transfer points instead of the final Destination. An easy way to calculate this is by calculating the ratio of inDegree (the number of flights to the airport) / outDegree (the number of flights leaving the airport). Values close to 1 may indicate many transfers, whereas values < 1 indicate many outgoing flights and > 1 indicate many incoming flights. Note, this is a simple calculation that does not take into account of timing or scheduling of flights, just the overall aggregate number within the dataset.

// Calculate the inDeg (flights into the airport) and outDeg (flights leaving the airport)
val inDeg = tripGraph.inDegrees
val outDeg = tripGraph.outDegrees

// Calculate the degreeRatio (inDeg/outDeg), perform inner join on "id" column
val degreeRatio = inDeg.join(outDeg, inDeg("id") === outDeg("id")).
  drop(outDeg("id")).
  selectExpr("id", "double(inDegree)/double(outDegree) as degreeRatio").
  cache()

// Join back to the `airports` DataFrame (instead of registering temp table as above)
val nonTransferAirports = degreeRatio.join(airports, degreeRatio("id") === airports("IATA")).
  selectExpr("id", "city", "degreeRatio").
  filter("degreeRatio < 0.9 or degreeRatio > 1.1")

// List out the city airports which have abnormal degree ratios
display(nonTransferAirports)
GFKGrand Forks1.3333333333333333
FAIFairbanks1.1232686980609419
OMENome0.5084745762711864
BRWBarrow0.28651685393258425
// Join back to the `airports` DataFrame (instead of registering temp table as above)
val transferAirports = degreeRatio.join(airports, degreeRatio("id") === airports("IATA")).
  selectExpr("id", "city", "degreeRatio").
  filter("degreeRatio between 0.9 and 1.1")
  
// List out the top 10 transfer city airports
display(transferAirports.orderBy("degreeRatio").limit(10))
0.000.100.200.300.400.500.600.700.800.901.00Minneapolis, MSPDallas, DFWSalt Lake City, SLCPhoenix, PHXHonolulu, Oahu, HNLTOOLTIPcity, iddegreeRatio

Breadth First Search

Breadth-first search (BFS) is designed to traverse the graph to quickly find the desired vertices (i.e. airports) and edges (i.e flights). Let's try to find the shortest number of connections between cities based on the dataset. Note, these examples do not take into account of time or distance, just hops between cities.

// Example 1: Direct Seattle to San Francisco
// This method returns a DataFrame of valid shortest paths from vertices matching "fromExpr" to vertices matching "toExpr"
val filteredPaths = tripGraph.bfs.fromExpr((col("id") === "SEA")).toExpr(col("id") === "SFO").maxPathLength(1).run()
display(filteredPaths)
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2010720,"delay":-2,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2012125,"delay":-3,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2011845,"delay":-4,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2011220,"delay":-5,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2010955,"delay":-4,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2011405,"delay":-2,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2020720,"delay":21,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2022125,"delay":7,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2021845,"delay":1,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2020610,"delay":-8,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2021220,"delay":67,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2021100,"delay":0,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2021405,"delay":6,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2030720,"delay":9,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2032125,"delay":2,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2031845,"delay":3,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2030610,"delay":-1,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2031220,"delay":1,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2030955,"delay":4,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2031100,"delay":6,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2031405,"delay":-3,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2040720,"delay":-1,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2042125,"delay":-2,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2041845,"delay":-4,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2041220,"delay":-3,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2040955,"delay":0,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2041100,"delay":-3,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2041405,"delay":-3,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2050720,"delay":-4,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2052125,"delay":-4,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2051845,"delay":0,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2050610,"delay":-4,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2051220,"delay":6,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2050955,"delay":-7,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2051100,"delay":-2,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2051405,"delay":-1,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2060720,"delay":-6,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2062125,"delay":67,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2061845,"delay":22,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2060610,"delay":-5,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2061220,"delay":35,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2060955,"delay":148,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2061100,"delay":25,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2061405,"delay":21,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2070720,"delay":0,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2072125,"delay":105,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2071845,"delay":203,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2070610,"delay":0,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2071220,"delay":139,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2070955,"delay":57,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2071100,"delay":113,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2071405,"delay":144,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2080720,"delay":67,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2082125,"delay":56,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2081845,"delay":43,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2081220,"delay":17,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2080955,"delay":121,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2081405,"delay":55,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2090715,"delay":2,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2092125,"delay":2,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2091835,"delay":124,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2090610,"delay":0,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2091220,"delay":68,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2091100,"delay":-5,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2091405,"delay":101,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2100715,"delay":9,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2102125,"delay":-3,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2101835,"delay":-1,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2100610,"delay":-2,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2101220,"delay":134,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2100955,"delay":107,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2101100,"delay":105,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2101405,"delay":105,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2110715,"delay":5,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2112125,"delay":4,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2111835,"delay":78,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2111220,"delay":23,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2110955,"delay":29,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2111100,"delay":0,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2111405,"delay":39,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2120715,"delay":49,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2122125,"delay":1,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2121835,"delay":-2,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2120610,"delay":-2,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2121220,"delay":49,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2120955,"delay":91,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2121100,"delay":97,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2121405,"delay":-4,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2130715,"delay":6,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2132125,"delay":-1,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2131835,"delay":9,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2130610,"delay":-2,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2131220,"delay":78,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2130955,"delay":108,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2131100,"delay":139,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2131405,"delay":-3,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2140715,"delay":-1,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2142125,"delay":13,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2141835,"delay":16,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}
{"id":"SEA","City":"Seattle","State":"WA","Country":"USA"}{"tripid":2140610,"delay":0,"src":"SEA","dst":"SFO","city_dst":"San Francisco","state_dst":"CA"}{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}

Showing the first 1000 rows.

As you can see, there are a number of direct flights between Seattle and San Francisco.

// Example 2: Direct San Francisco and Buffalo
// You can also specify expression as a String, instead of Column
val filteredPaths = tripGraph.bfs.fromExpr("id = 'SFO'").toExpr("id = 'BUF'").maxPathLength(1).run()
filteredPaths: org.apache.spark.sql.DataFrame = [id: string, City: string ... 2 more fields]
filteredPaths.show()
+---+----+-----+-------+ | id|City|State|Country| +---+----+-----+-------+ +---+----+-----+-------+
display(filteredPaths) // display instead of show - same diference
OK

But there are no direct flights between San Francisco and Buffalo.

// Example 2a: Flying from San Francisco to Buffalo
val filteredPaths = tripGraph.bfs.fromExpr("id = 'SFO'").toExpr("id = 'BUF'").maxPathLength(2).run()
display(filteredPaths)
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":3010630,"delay":-4,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":3011445,"delay":8,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":3020630,"delay":-5,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":3021049,"delay":-7,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":3021445,"delay":-3,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":3030630,"delay":0,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":3031049,"delay":-3,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":3031445,"delay":-3,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":3040630,"delay":-8,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":3041049,"delay":-11,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":3041445,"delay":15,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":3050630,"delay":-6,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":3051049,"delay":-10,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":3051445,"delay":-10,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":3060630,"delay":-10,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":3061049,"delay":-7,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":3061455,"delay":27,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":3061730,"delay":-3,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":3070630,"delay":-9,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":3071049,"delay":-6,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":3071455,"delay":-9,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":3071730,"delay":48,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":3080630,"delay":-7,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":3081455,"delay":-6,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":3090630,"delay":-6,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":3091049,"delay":-8,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":3091430,"delay":-4,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":3091730,"delay":-3,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":3100630,"delay":-3,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":3101049,"delay":33,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":3101530,"delay":15,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":3110630,"delay":-11,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":3111049,"delay":-10,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":3111530,"delay":-5,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":3120630,"delay":54,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":3121049,"delay":0,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":3121530,"delay":0,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":3130630,"delay":-5,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":3131049,"delay":27,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":3131530,"delay":20,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":3140630,"delay":-7,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":3141049,"delay":1,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":3141530,"delay":-5,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":3150630,"delay":-6,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":3151530,"delay":-4,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":3160630,"delay":-5,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":3161049,"delay":-12,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":3161530,"delay":-6,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":3170630,"delay":-1,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":3171049,"delay":11,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":3171530,"delay":-7,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":3180630,"delay":-6,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":3181049,"delay":-6,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":3181530,"delay":-8,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":3190630,"delay":-4,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":3191049,"delay":12,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":3191530,"delay":-4,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":3200630,"delay":-5,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":3201049,"delay":-4,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":3201530,"delay":0,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":3210630,"delay":-7,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":3211049,"delay":-8,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":3211530,"delay":-10,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":3220630,"delay":-10,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":3221530,"delay":-7,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":3230630,"delay":-10,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":3231049,"delay":-8,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":3231530,"delay":-8,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":3240630,"delay":-4,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":3241049,"delay":-9,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":3241530,"delay":-7,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":3250630,"delay":-2,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":3251049,"delay":13,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":3251530,"delay":-1,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":3260630,"delay":0,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":3261049,"delay":-9,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":3261530,"delay":-2,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":3270630,"delay":-9,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":3271049,"delay":-2,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":3271530,"delay":-3,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":3280630,"delay":-9,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":3281049,"delay":-3,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":3281530,"delay":-4,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":3290630,"delay":-4,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":3291530,"delay":-4,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":3300633,"delay":-12,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":3301055,"delay":2,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":3301539,"delay":-13,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":3310630,"delay":-6,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":3311055,"delay":22,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":3311539,"delay":26,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":1010635,"delay":-6,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":1011059,"delay":13,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":1011427,"delay":19,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":1020635,"delay":-4,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":1021059,"delay":0,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":1021427,"delay":194,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":1030635,"delay":0,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":1031059,"delay":0,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}
{"id":"SFO","City":"San Francisco","State":"CA","Country":"USA"}{"tripid":2010700,"delay":5,"src":"SFO","dst":"BOS","city_dst":"Boston","state_dst":"MA"}{"id":"BOS","City":"Boston","State":"MA","Country":"USA"}{"tripid":1031427,"delay":0,"src":"BOS","dst":"BUF","city_dst":"Buffalo","state_dst":"NY"}{"id":"BUF","City":"Buffalo","State":"NY","Country":"USA"}

Showing the first 1000 rows.

But there are flights from San Francisco to Buffalo with Minneapolis as the transfer point.

Loading the D3 Visualization

Using the airports D3 visualization to visualize airports and flight paths

Show code
Warning: classes defined within packages cannot be redefined without a cluster restart. Compilation successful.
d3a.graphs.help()

Visualize On-time and Early Arrivals

// On-time and Early Arrivals
import d3a._

graphs.force(
  height = 800,
  width = 1200,
  clicks = sql("select src, dst as dest, count(1) as count from departureDelays_geo where delay <= 0 group by src, dst").as[Edge])

Visualize Delayed Trips Departing from the West Coast

Notice that most of the delayed trips are with Western US cities