Situación Problema

Te acabas de incorporar a una empresa consultora en Inteligencia de Negocios, actualmente están brindando servicios de análisis para la industria de la aviación y les interesa tener a la aerolínea American Airlines como cliente ya que es una de las aerolíneas líderes en los aeropuertos de Nueva York, motivo por el cuál te han contratado.

Te han pedido que identifiques cómo puede dicha aerolínea mejorar su posición competitiva !!

Para identificar oportunidades de mejorar la posición competitiva de la aerolínea American Airlines, necesitas realizar algunos análisis, para determinar si hay variaciones en la posición de liderazgo de dicha aerolínea.

Modelo Entidad-Relación

Se te ha solicitado hacer un estudio sobre la situación actual de la aerolínea American Airlines ya que se necesita revisar sus destinos, horarios y aviones con los que cuenta para hacer propuestas de aumento o reducción de vuelos por destino y horarios, así como la cantidad de aviones.

Para lograrlo considera las funciones sugeridas en los siguientes pasos:

library(nycflights13)
library(dplyr)
## 
## Attaching package: 'dplyr'
## The following objects are masked from 'package:stats':
## 
##     filter, lag
## The following objects are masked from 'package:base':
## 
##     intersect, setdiff, setequal, union

Consulta y explora el data frame planes y weather para que conozcas su contenido.

#View(planes)
#View(weather)

Se necesita saber de cada vuelo, la aerolínea, el aeropuerto de origen y el aeropuerto destino.

summary(flights)
##       year          month             day           dep_time    sched_dep_time
##  Min.   :2013   Min.   : 1.000   Min.   : 1.00   Min.   :   1   Min.   : 106  
##  1st Qu.:2013   1st Qu.: 4.000   1st Qu.: 8.00   1st Qu.: 907   1st Qu.: 906  
##  Median :2013   Median : 7.000   Median :16.00   Median :1401   Median :1359  
##  Mean   :2013   Mean   : 6.549   Mean   :15.71   Mean   :1349   Mean   :1344  
##  3rd Qu.:2013   3rd Qu.:10.000   3rd Qu.:23.00   3rd Qu.:1744   3rd Qu.:1729  
##  Max.   :2013   Max.   :12.000   Max.   :31.00   Max.   :2400   Max.   :2359  
##                                                  NA's   :8255                 
##    dep_delay          arr_time    sched_arr_time   arr_delay       
##  Min.   : -43.00   Min.   :   1   Min.   :   1   Min.   : -86.000  
##  1st Qu.:  -5.00   1st Qu.:1104   1st Qu.:1124   1st Qu.: -17.000  
##  Median :  -2.00   Median :1535   Median :1556   Median :  -5.000  
##  Mean   :  12.64   Mean   :1502   Mean   :1536   Mean   :   6.895  
##  3rd Qu.:  11.00   3rd Qu.:1940   3rd Qu.:1945   3rd Qu.:  14.000  
##  Max.   :1301.00   Max.   :2400   Max.   :2359   Max.   :1272.000  
##  NA's   :8255      NA's   :8713                  NA's   :9430      
##    carrier              flight       tailnum             origin         
##  Length:336776      Min.   :   1   Length:336776      Length:336776     
##  Class :character   1st Qu.: 553   Class :character   Class :character  
##  Mode  :character   Median :1496   Mode  :character   Mode  :character  
##                     Mean   :1972                                        
##                     3rd Qu.:3465                                        
##                     Max.   :8500                                        
##                                                                         
##      dest              air_time        distance         hour      
##  Length:336776      Min.   : 20.0   Min.   :  17   Min.   : 1.00  
##  Class :character   1st Qu.: 82.0   1st Qu.: 502   1st Qu.: 9.00  
##  Mode  :character   Median :129.0   Median : 872   Median :13.00  
##                     Mean   :150.7   Mean   :1040   Mean   :13.18  
##                     3rd Qu.:192.0   3rd Qu.:1389   3rd Qu.:17.00  
##                     Max.   :695.0   Max.   :4983   Max.   :23.00  
##                     NA's   :9430                                  
##      minute        time_hour                     
##  Min.   : 0.00   Min.   :2013-01-01 05:00:00.00  
##  1st Qu.: 8.00   1st Qu.:2013-04-04 13:00:00.00  
##  Median :29.00   Median :2013-07-03 10:00:00.00  
##  Mean   :26.23   Mean   :2013-07-03 05:22:54.64  
##  3rd Qu.:44.00   3rd Qu.:2013-10-01 07:00:00.00  
##  Max.   :59.00   Max.   :2013-12-31 23:00:00.00  
## 
vuelos = select(flights, flight, carrier, origin, dest)
head(vuelos)
## # A tibble: 6 × 4
##   flight carrier origin dest 
##    <int> <chr>   <chr>  <chr>
## 1   1545 UA      EWR    IAH  
## 2   1714 UA      LGA    IAH  
## 3   1141 AA      JFK    MIA  
## 4    725 B6      JFK    BQN  
## 5    461 DL      LGA    ATL  
## 6   1696 UA      EWR    ORD

En la consulta anterior se necesita conocer el nombre de la aerolínea.

head(airlines)
## # A tibble: 6 × 2
##   carrier name                    
##   <chr>   <chr>                   
## 1 9E      Endeavor Air Inc.       
## 2 AA      American Airlines Inc.  
## 3 AS      Alaska Airlines Inc.    
## 4 B6      JetBlue Airways         
## 5 DL      Delta Air Lines Inc.    
## 6 EV      ExpressJet Airlines Inc.
?left_join()
## starting httpd help server ... done

Se necesita saber la cantidad de vuelos por cada destino para identificar cuáles son los destinos más buscados.

count(vuelos, dest, sort = TRUE)
## # A tibble: 105 × 2
##    dest      n
##    <chr> <int>
##  1 ORD   17283
##  2 ATL   17215
##  3 LAX   16174
##  4 BOS   15508
##  5 MCO   14082
##  6 CLT   14064
##  7 SFO   13331
##  8 FLL   12055
##  9 MIA   11728
## 10 DCA    9705
## # … with 95 more rows

Agregar el nombre de la aerolínea al data frame anterior.

#left_join()

Se necesita conocer las aerolíneas (clave y nombre) y destinos que vuelan por la Mañana: de 6 a 12, Tarde: de 12 a 19 , Noche: de 19 a 24 y Madrugada de 24 a 6.

horarios = select(flights, flight, carrier, dest, hour)
head(horarios)
## # A tibble: 6 × 4
##   flight carrier dest   hour
##    <int> <chr>   <chr> <dbl>
## 1   1545 UA      IAH       5
## 2   1714 UA      IAH       5
## 3   1141 AA      MIA       5
## 4    725 B6      BQN       5
## 5    461 DL      ATL       6
## 6   1696 UA      ORD       5
#horarios$categoria = if(flights$hour >= 6 & flights$hour < 12){
#  "Mañana"
#}

Se necesita saber la cantidad de vuelos por aerolínea y destino que hay por la Mañana, Tarde, Noche y Madrugada.

Función: group_by() y count()

Se necesita saber a qué destinos vuela la aerolínea American Airlines Inc.-AA durante la madrugada.

Función: select(),filter(),group_by()

¿Qué aviones utiliza la aerolínea AA? aerolínea, tipo, motor y número de asientos y ¿Cuántos vuelos se han realizado con cada uno? elimina los NA’s

#head(planes)
aviones = select(planes, type, engine, seats)

Imagina que entregarás estos hallazgos a tu superior, elabora un reporte ejecutivo utilizando los resultados obtenidos. ABC

Visualización de datos

En los avances anteriores se han realizado diferentes análisis y ahora nos solicitan hacer visualizaciones de la aerolínea American Airlines para los ejecutivos con las siguientes características.

Dentro de las aerolíneas el retraso tanto en la hora de partida como en la hora de llegada a su destino van generando indicadores negativos.

Se solicita analizar para la aerolínea American Airlines si los vuelos que tienen retraso en la partida también tienen retraso en la hora de llegada.

Realiza una visualización con una gráfica Scatterplot.

Visualiza la tendencia de la temperatura durante los primeros 15 días del mes de Enero en los vuelos que parten del aeropuerto “Newark, EWR”, utilizar una gráfica de línea.

head(weather)
## # A tibble: 6 × 15
##   origin  year month   day  hour  temp  dewp humid wind_dir wind_speed wind_gust
##   <chr>  <int> <int> <int> <int> <dbl> <dbl> <dbl>    <dbl>      <dbl>     <dbl>
## 1 EWR     2013     1     1     1  39.0  26.1  59.4      270      10.4         NA
## 2 EWR     2013     1     1     2  39.0  27.0  61.6      250       8.06        NA
## 3 EWR     2013     1     1     3  39.0  28.0  64.4      240      11.5         NA
## 4 EWR     2013     1     1     4  39.9  28.0  62.2      250      12.7         NA
## 5 EWR     2013     1     1     5  39.0  28.0  64.4      260      12.7         NA
## 6 EWR     2013     1     1     6  37.9  28.0  67.2      240      11.5         NA
## # … with 4 more variables: precip <dbl>, pressure <dbl>, visib <dbl>,
## #   time_hour <dttm>
g1 = filter(weather, origin=="EWR")
g2 = filter(g1, day <= 15)
g3 = filter(g2, month == 1)

#g4 = summarize_if(is.numeric, ~mean(.,na.rm=TRUE))
plot(g3$day, g3$temp, type = "l")

• Visualiza la temperatura más frecuente en los primeros 15 días del mes de Enero, utilizar un histrograma.
• Utiliza Facets para observar cómo varía la temperatura en cada mes en él histograma del punto anterior .
• Número de vuelos que salieron de Nueva York en 2013 por aerolínea (mostrar solamente las 10 aerolíneas con más vuelos), utilizar gráfica de barras.
• Visualiza el punto anterior en una gráfica de pie.
• Relaciona el data frame fligths con el data frame airports a través del campo destino ¿cómo lograr estas relación?
• Crea un nuevo data frame con el punto anterior únicamente con los 5 carriers con más vuelos por destino.

Compromiso ético y ciudadano

• Describe el valor de la integridad.
• Agrega una reflexión personal de cómo puedes actuar con respeto y honestidad en los negocios y en el uso de datos cuando realices análisis de datos y estés en contacto con los datos de una empresa.
• Agrega al menos 3 bibliografías y cítalas en el punto anterior.

http://codigoeticaeintegridad.com/

Bibliografía

Wickham, H. and Grolemund, G. (2017) R for Data Science: Import, Tidy, Transform, Visualize, and Model Data O’Reilly Media: Sebastopol, California

Nycflights13 v1.0.0 https://www.rdocumentation.org/packages/nycflights13/versions/1.0.0

LS0tDQordGl0bGU6ICJTaXR1YWNpw7NuIFByb2JsZW1hIDIiDQphdXRob3I6ICJKb3PDqSBBcnR1cm8gU2lsdmEgRmxvcmVzIEEwMTE5ODA0OSINCmRhdGU6ICIyMDIzLTAzLTE3Ig0Kb3V0cHV0OiANCiAgaHRtbF9kb2N1bWVudDoNCiAgICB0b2M6IHRydWUNCiAgICB0b2NfZmxvYXQ6IHRydWUNCiAgICBjb2RlX2Rvd25sb2FkOiB0cnVlDQotLS0NCg0KIVtdKEM6XFxVc2Vyc1xcU2lsdmFcXERvY3VtZW50c1xcYXZpb24ucG5nKQ0KDQojIyMgU2l0dWFjacOzbiBQcm9ibGVtYSANCg0KVGUgYWNhYmFzIGRlIGluY29ycG9yYXIgYSB1bmEgZW1wcmVzYSBjb25zdWx0b3JhIGVuIEludGVsaWdlbmNpYSBkZSBOZWdvY2lvcywgYWN0dWFsbWVudGUgZXN0w6FuDQpicmluZGFuZG8gc2VydmljaW9zIGRlIGFuw6FsaXNpcyBwYXJhIGxhIGluZHVzdHJpYSBkZSBsYSBhdmlhY2nDs24geSBsZXMgaW50ZXJlc2EgdGVuZXIgYSBsYSBhZXJvbMOtbmVhDQpBbWVyaWNhbiBBaXJsaW5lcyBjb21vIGNsaWVudGUgeWEgcXVlIGVzIHVuYSBkZSBsYXMgYWVyb2zDrW5lYXMgbMOtZGVyZXMgZW4gbG9zIGFlcm9wdWVydG9zIGRlIE51ZXZhDQpZb3JrLCBtb3Rpdm8gcG9yIGVsIGN1w6FsIHRlIGhhbiBjb250cmF0YWRvLiAgDQoNClRlIGhhbiBwZWRpZG8gcXVlIGlkZW50aWZpcXVlcyBjw7NtbyBwdWVkZSBkaWNoYSBhZXJvbMOtbmVhIG1lam9yYXIgc3UgcG9zaWNpw7NuIGNvbXBldGl0aXZhICEhICANCg0KUGFyYSBpZGVudGlmaWNhciBvcG9ydHVuaWRhZGVzIGRlIG1lam9yYXIgbGEgcG9zaWNpw7NuIGNvbXBldGl0aXZhIGRlIGxhIGFlcm9sw61uZWEgQW1lcmljYW4gQWlybGluZXMsDQpuZWNlc2l0YXMgcmVhbGl6YXIgYWxndW5vcyBhbsOhbGlzaXMsIHBhcmEgZGV0ZXJtaW5hciBzaSBoYXkgdmFyaWFjaW9uZXMgZW4gbGEgcG9zaWNpw7NuIGRlIGxpZGVyYXpnbw0KZGUgZGljaGEgYWVyb2zDrW5lYS4gIA0KDQojIyMgTW9kZWxvIEVudGlkYWQtUmVsYWNpw7NuDQoNClNlIHRlIGhhIHNvbGljaXRhZG8gaGFjZXIgdW4gZXN0dWRpbyBzb2JyZSBsYSBzaXR1YWNpw7NuIGFjdHVhbCBkZSBsYSBhZXJvbMOtbmVhIEFtZXJpY2FuIEFpcmxpbmVzIHlhDQpxdWUgc2UgbmVjZXNpdGEgcmV2aXNhciBzdXMgZGVzdGlub3MsIGhvcmFyaW9zIHkgYXZpb25lcyBjb24gbG9zIHF1ZSBjdWVudGEgcGFyYSBoYWNlciBwcm9wdWVzdGFzDQpkZSBhdW1lbnRvIG8gcmVkdWNjacOzbiBkZSB2dWVsb3MgcG9yIGRlc3Rpbm8geSBob3JhcmlvcywgYXPDrSBjb21vIGxhIGNhbnRpZGFkIGRlIGF2aW9uZXMuICANCg0KUGFyYSBsb2dyYXJsbyBjb25zaWRlcmEgbGFzIGZ1bmNpb25lcyBzdWdlcmlkYXMgZW4gbG9zIHNpZ3VpZW50ZXMgcGFzb3M6ICANCmBgYHtyfQ0KbGlicmFyeShueWNmbGlnaHRzMTMpDQpsaWJyYXJ5KGRwbHlyKQ0KYGBgDQoNCg0KKipDb25zdWx0YSB5IGV4cGxvcmEgZWwgZGF0YSBmcmFtZSBwbGFuZXMgeSB3ZWF0aGVyIHBhcmEgcXVlIGNvbm96Y2FzIHN1IGNvbnRlbmlkby4qKg0KYGBge3J9DQojVmlldyhwbGFuZXMpDQojVmlldyh3ZWF0aGVyKQ0KYGBgDQoNCioqU2UgbmVjZXNpdGEgc2FiZXIgZGUgY2FkYSB2dWVsbywgbGEgYWVyb2zDrW5lYSwgZWwgYWVyb3B1ZXJ0byBkZSBvcmlnZW4geSBlbCBhZXJvcHVlcnRvIGRlc3Rpbm8uKioNCmBgYHtyfQ0Kc3VtbWFyeShmbGlnaHRzKQ0KdnVlbG9zID0gc2VsZWN0KGZsaWdodHMsIGZsaWdodCwgY2Fycmllciwgb3JpZ2luLCBkZXN0KQ0KaGVhZCh2dWVsb3MpDQpgYGANCg0KKipFbiBsYSBjb25zdWx0YSBhbnRlcmlvciBzZSBuZWNlc2l0YSBjb25vY2VyIGVsIG5vbWJyZSBkZSBsYSBhZXJvbMOtbmVhLioqDQpgYGB7cn0NCmhlYWQoYWlybGluZXMpDQo/bGVmdF9qb2luKCkNCmBgYA0KDQoqKlNlIG5lY2VzaXRhIHNhYmVyIGxhIGNhbnRpZGFkIGRlIHZ1ZWxvcyBwb3IgY2FkYSBkZXN0aW5vIHBhcmEgaWRlbnRpZmljYXIgY3XDoWxlcyBzb24gbG9zIGRlc3Rpbm9zIG3DoXMgYnVzY2Fkb3MuKioNCmBgYHtyfQ0KY291bnQodnVlbG9zLCBkZXN0LCBzb3J0ID0gVFJVRSkNCmBgYA0KDQoqKkFncmVnYXIgZWwgbm9tYnJlIGRlIGxhIGFlcm9sw61uZWEgYWwgZGF0YSBmcmFtZSBhbnRlcmlvci4qKg0KYGBge3J9DQojbGVmdF9qb2luKCkNCmBgYA0KDQoNCioqU2UgbmVjZXNpdGEgY29ub2NlciBsYXMgYWVyb2zDrW5lYXMgKGNsYXZlIHkgbm9tYnJlKSB5IGRlc3Rpbm9zIHF1ZSB2dWVsYW4gcG9yIGxhIE1hw7FhbmE6IGRlIDYgYSAxMiwgVGFyZGU6IGRlIDEyIGEgMTkgLCBOb2NoZTogZGUgMTkgYSAyNCB5IE1hZHJ1Z2FkYSBkZSAyNCBhIDYuKioNCmBgYHtyfQ0KaG9yYXJpb3MgPSBzZWxlY3QoZmxpZ2h0cywgZmxpZ2h0LCBjYXJyaWVyLCBkZXN0LCBob3VyKQ0KaGVhZChob3JhcmlvcykNCiNob3JhcmlvcyRjYXRlZ29yaWEgPSBpZihmbGlnaHRzJGhvdXIgPj0gNiAmIGZsaWdodHMkaG91ciA8IDEyKXsNCiMgICJNYcOxYW5hIg0KI30NCg0KYGBgDQoNCg0KKipTZSBuZWNlc2l0YSBzYWJlciBsYSBjYW50aWRhZCBkZSB2dWVsb3MgcG9yIGFlcm9sw61uZWEgeSBkZXN0aW5vIHF1ZSBoYXkgcG9yIGxhIE1hw7FhbmEsIFRhcmRlLCBOb2NoZSB5IE1hZHJ1Z2FkYS4qKg0KYGBge3J9DQoNCmBgYA0KDQpGdW5jacOzbjogZ3JvdXBfYnkoKSB5IGNvdW50KCkNCg0KKipTZSBuZWNlc2l0YSBzYWJlciBhIHF1w6kgZGVzdGlub3MgdnVlbGEgbGEgYWVyb2zDrW5lYSBBbWVyaWNhbiBBaXJsaW5lcyBJbmMuLUFBICBkdXJhbnRlIGxhIG1hZHJ1Z2FkYS4qKg0KYGBge3J9DQoNCmBgYA0KDQpGdW5jacOzbjogc2VsZWN0KCksZmlsdGVyKCksZ3JvdXBfYnkoKQ0KDQoqKsK/UXXDqSBhdmlvbmVzIHV0aWxpemEgbGEgYWVyb2zDrW5lYSBBQT8gYWVyb2zDrW5lYSwgdGlwbywgbW90b3IgeSBuw7ptZXJvIGRlIGFzaWVudG9zIHkgwr9DdcOhbnRvcyB2dWVsb3Mgc2UgaGFuIHJlYWxpemFkbyBjb24gY2FkYSB1bm8/IGVsaW1pbmEgbG9zIE5BJ3MqKg0KYGBge3J9DQojaGVhZChwbGFuZXMpDQphdmlvbmVzID0gc2VsZWN0KHBsYW5lcywgdHlwZSwgZW5naW5lLCBzZWF0cykNCmBgYA0KDQoqKkltYWdpbmEgcXVlIGVudHJlZ2Fyw6FzIGVzdG9zIGhhbGxhemdvcyBhIHR1IHN1cGVyaW9yLCBlbGFib3JhIHVuIHJlcG9ydGUgZWplY3V0aXZvIHV0aWxpemFuZG8gbG9zIHJlc3VsdGFkb3Mgb2J0ZW5pZG9zLioqDQpBQkMNCg0KIyMjIFZpc3VhbGl6YWNpw7NuIGRlIGRhdG9zDQoNCkVuIGxvcyBhdmFuY2VzIGFudGVyaW9yZXMgc2UgaGFuIHJlYWxpemFkbyBkaWZlcmVudGVzIGFuw6FsaXNpcyB5IGFob3JhIG5vcyBzb2xpY2l0YW4gaGFjZXIgdmlzdWFsaXphY2lvbmVzIGRlIGxhIGFlcm9sw61uZWEgQW1lcmljYW4gQWlybGluZXMgcGFyYSBsb3MgZWplY3V0aXZvcyBjb24gbGFzIHNpZ3VpZW50ZXMgY2FyYWN0ZXLDrXN0aWNhcy4gIA0KDQpEZW50cm8gZGUgbGFzIGFlcm9sw61uZWFzIGVsIHJldHJhc28gdGFudG8gZW4gbGEgaG9yYSBkZSBwYXJ0aWRhIGNvbW8gZW4gbGEgaG9yYSBkZSBsbGVnYWRhIGEgc3UgZGVzdGlubyB2YW4gZ2VuZXJhbmRvIGluZGljYWRvcmVzIG5lZ2F0aXZvcy4gICANCg0KU2Ugc29saWNpdGEgYW5hbGl6YXIgcGFyYSBsYSBhZXJvbMOtbmVhIEFtZXJpY2FuIEFpcmxpbmVzIHNpIGxvcyB2dWVsb3MgcXVlIHRpZW5lbiByZXRyYXNvIGVuIGxhIHBhcnRpZGEgdGFtYmnDqW4gdGllbmVuIHJldHJhc28gZW4gbGEgaG9yYSBkZSBsbGVnYWRhLg0KDQpSZWFsaXphIHVuYSB2aXN1YWxpemFjacOzbiBjb24gdW5hIGdyw6FmaWNhIFNjYXR0ZXJwbG90LiAgDQoNCioqVmlzdWFsaXphIGxhIHRlbmRlbmNpYSBkZSBsYSB0ZW1wZXJhdHVyYSBkdXJhbnRlIGxvcyBwcmltZXJvcyAxNSBkw61hcyBkZWwgbWVzIGRlIEVuZXJvIGVuIGxvcyB2dWVsb3MgcXVlIHBhcnRlbiBkZWwgYWVyb3B1ZXJ0byDigJxOZXdhcmssICBFV1LigJ0sIHV0aWxpemFyIHVuYSBncsOhZmljYSBkZSBsw61uZWEuKioNCmBgYHtyfQ0KaGVhZCh3ZWF0aGVyKQ0KZzEgPSBmaWx0ZXIod2VhdGhlciwgb3JpZ2luPT0iRVdSIikNCmcyID0gZmlsdGVyKGcxLCBkYXkgPD0gMTUpDQpnMyA9IGZpbHRlcihnMiwgbW9udGggPT0gMSkNCg0KI2c0ID0gc3VtbWFyaXplX2lmKGlzLm51bWVyaWMsIH5tZWFuKC4sbmEucm09VFJVRSkpDQpwbG90KGczJGRheSwgZzMkdGVtcCwgdHlwZSA9ICJsIikNCmBgYA0KDQrigKIJVmlzdWFsaXphIGxhIHRlbXBlcmF0dXJhIG3DoXMgZnJlY3VlbnRlIGVuIGxvcyBwcmltZXJvcyAxNSBkw61hcyBkZWwgbWVzIGRlIEVuZXJvLCB1dGlsaXphciB1biBoaXN0cm9ncmFtYS4gIA0K4oCiCVV0aWxpemEgRmFjZXRzIHBhcmEgb2JzZXJ2YXIgY8OzbW8gdmFyw61hIGxhIHRlbXBlcmF0dXJhIGVuIGNhZGEgbWVzIGVuIMOpbCBoaXN0b2dyYW1hIGRlbCBwdW50byBhbnRlcmlvciAuICANCuKAoglOw7ptZXJvIGRlIHZ1ZWxvcyBxdWUgc2FsaWVyb24gZGUgTnVldmEgWW9yayBlbiAyMDEzIHBvciBhZXJvbMOtbmVhIChtb3N0cmFyIHNvbGFtZW50ZSBsYXMgMTAgYWVyb2zDrW5lYXMgY29uIG3DoXMgdnVlbG9zKSwgdXRpbGl6YXIgZ3LDoWZpY2EgZGUgYmFycmFzLiAgDQrigKIJVmlzdWFsaXphIGVsIHB1bnRvIGFudGVyaW9yIGVuIHVuYSBncsOhZmljYSBkZSBwaWUuICANCuKAoglSZWxhY2lvbmEgZWwgZGF0YSBmcmFtZSBmbGlndGhzIGNvbiBlbCBkYXRhIGZyYW1lIGFpcnBvcnRzIGEgdHJhdsOpcyBkZWwgY2FtcG8gZGVzdGlubyDCv2PDs21vIGxvZ3JhciBlc3RhcyByZWxhY2nDs24/ICANCuKAoglDcmVhIHVuIG51ZXZvIGRhdGEgZnJhbWUgY29uIGVsIHB1bnRvIGFudGVyaW9yIMO6bmljYW1lbnRlIGNvbiBsb3MgNSBjYXJyaWVycyBjb24gbcOhcyB2dWVsb3MgcG9yIGRlc3Rpbm8uICANCg0KIyMjIENvbXByb21pc28gw6l0aWNvIHkgY2l1ZGFkYW5vDQoNCuKAoglEZXNjcmliZSBlbCB2YWxvciBkZSBsYSBpbnRlZ3JpZGFkLiAgDQrigKIJQWdyZWdhIHVuYSByZWZsZXhpw7NuIHBlcnNvbmFsIGRlIGPDs21vIHB1ZWRlcyBhY3R1YXIgY29uIHJlc3BldG8geSBob25lc3RpZGFkIGVuIGxvcyBuZWdvY2lvcyB5IGVuIGVsIHVzbyBkZSBkYXRvcyBjdWFuZG8gcmVhbGljZXMgYW7DoWxpc2lzIGRlIGRhdG9zIHkgZXN0w6lzIGVuIGNvbnRhY3RvIGNvbiBsb3MgZGF0b3MgZGUgdW5hIGVtcHJlc2EuICANCuKAoglBZ3JlZ2EgYWwgbWVub3MgMyBiaWJsaW9ncmFmw61hcyB5IGPDrXRhbGFzIGVuIGVsIHB1bnRvIGFudGVyaW9yLiAgDQoNCmh0dHA6Ly9jb2RpZ29ldGljYWVpbnRlZ3JpZGFkLmNvbS8NCg0KIyMjIEJpYmxpb2dyYWbDrWENCg0KV2lja2hhbSwgSC4gYW5kIEdyb2xlbXVuZCwgRy4gKDIwMTcpIFIgZm9yIERhdGEgU2NpZW5jZTogSW1wb3J0LCBUaWR5LCBUcmFuc2Zvcm0sIFZpc3VhbGl6ZSwgYW5kIE1vZGVsIERhdGEgT+KAmVJlaWxseSBNZWRpYTogU2ViYXN0b3BvbCwgQ2FsaWZvcm5pYSAgDQoNCk55Y2ZsaWdodHMxMyB2MS4wLjAgaHR0cHM6Ly93d3cucmRvY3VtZW50YXRpb24ub3JnL3BhY2thZ2VzL255Y2ZsaWdodHMxMy92ZXJzaW9ucy8xLjAuMCANCg0KDQo=