Getting Started with R,Part 2 Let us
continue getting started with R as we start discussing important
statistical concepts in Sports Analytics.
Case-scenario 1 This is the fourth season of
outfielder Luis Robert with the Chicago White Socks. If during the first
three seasons he hit 11, 13, and 12 home runs, how many does he need on
this season for his overall average to be at least 20?
Solution Given that x1=11,x2=13,x3=12
we want to find x4 such that the mean (average) number of home-runs
is x¯>=20
Notice that in this case n=4 .
According to the information above: 20×4=11+13+12+x4
so when x4=44 , the home-runs average will be 20.
# Home-runs so far
HR_before <- c(11, 13, 12)
# Average Number of Home-runs per season wanted
wanted_HR <- 20
# Number of seasons
n_seasons <- 4
# Needed Home-runs on season 4
x_4 <- n_seasons*wanted_HR - sum(HR_before)
# Minimum number of Home-runs needed by Robert
x_4
[1] 44
According to the calculations above, Robert must hit 44 home-runs or
better on this season to get an average number of home-runs per season
of at least 20.
We could confirm this, by using the function mean() in R
# Division
# Robert's performance
Robert_HRs <- c(11, 13, 12,44)
# Find mean
mean(Robert_HRs)
[1] 20
Question 3 Use the skills learned in case scenario
number 3 on one the following data sets. You may choose only one
dataset. They are both available in Canvas.
doubles_hit.csv and triples_hit.csv
# Find standard deviation
sd(Robert_HRs)
[1] 16.02082
# Find the maximum number of home-runs during the four seasons period
max(Robert_HRs)
[1] 44
# Find the minimum number of home-runs during the four seasons period
min(Robert_HRs)
[1] 11
We can also use the summary() function to find basic statistics,
including the median!
summary(Robert_HRs)
Min. 1st Qu. Median Mean 3rd Qu. Max.
11.00 11.75 12.50 20.00 20.75 44.00
Question 1 Now, you must complete the
problem below which represents a similar case scenario. You may use the
steps that we executed in Case-scenario 1 as a template for your
solution.
This is the sixth season of outfielder Juan Soto in the majors. If
during the first five seasons he received 79, 108,41,145, and 135 walks,
how many does he need on this season for his overall number of walks per
season to be at least 100?
# Walks so far
Walks_before <- c(79, 108,41,145, 135)
# Average Number of Home-runs per season wanted
wanted_walks <- 100
# Number of seasons
JSn_seasons <- 6
# Needed walks on season 6
x_6 <- JSn_seasons*wanted_walks - sum(Walks_before)
# Minimum number of Walks needed by Juan Soto
x_6
[1] 92
Case-scenario 2 The average salary of 10
baseball players is 72,000 dollars a week and the average salary of 4
soccer players is 84,000. Find the mean salary of all 14 professional
players.
Solution We can easily find the joined mean by
adding both mean and dividing by the total number of people.
Let n1=10 denote the number of baseball players, and y1=72000 their
mean salary. Let n2=4 the number of soccer players and y2=84000 their
mean salary. Then the mean salary of all 16 individuals is:
(n1x1+n2x2)/(n1+n2)
We can compute this in R as follows:
n_1 <- 10
n_2 <- 4
y_1 <- 72000
y_2 <- 84000
# Mean salary overall
salary_ave <- (n_1*y_1 + n_2*y_2)/(n_1+n_2)
salary_ave
[1] 75428.57
Question 2 The average salary of 7
basketball players is 102,000 dollars a week and the average salary of 9
NFL players is 91,000. Find the mean salary of all 16 professional
players.
n_3 <- 7
n_4 <- 9
y_3 <- 102000
y_4 <- 91000
# Mean salary overall
salary_ave_bask_nfl <- (n_3*y_3 + n_4*y_4)/(n_3+n_4)
salary_ave_bask_nfl
[1] 95812.5
Case-scenario 3 The frequency distribution
below lists the number of active players in the Barclays Premier League
and the time left in their contract.
Years Number of players 6 28 5 72 4 201 3 109 2 56 1 34
1.Find the mean,the median and the standard deviation.
2.What percentage of the data lies within one standard deviation of
the mean?
3.What percentage of the data lies within two standard deviations of
the mean?
4.What percent of the data lies within three standard deviations of
the mean?
5.Draw a histogram to illustrate the data.
Solution The allcontracts.csv file contains
all the players’ contracts length. We can read this file in R using the
read.csv() function.
#This assigns the resulting data frame to the variable to contract_length
contract_length <- read.csv("C:/Users/auris/Downloads/allcontracts.csv",header = TRUE, sep = ",")
# This assigns the values of the specified column to the variable contract_years
contract_years <- contract_length$years
Make comments about the code we just ran above.
To find the mean and the standard deviation
# Mean
contracts_mean <- mean(contract_years)
contracts_mean
[1] 3.458918
# Median
contracts_median <- median(contract_years)
contracts_median
[1] 3
# Find number of observations
contracts_n <- length(contract_years)
# Find standard deviation
contracts_sd <- sd(contract_years)
2.- What percentage of the data lies within one standard deviation of
the mean?
contracts_w1sd <- sum((contract_years - contracts_mean)/contracts_sd < 1)/ contracts_n
# Percentage of observation within one standard deviation of the mean
contracts_w1sd
[1] 0.8416834
## Difference from empirical
contracts_w1sd - 0.68
[1] 0.1616834
3.What percentage of the data lies within two standard deviations of
the mean?
## Within 2 sd
contracts_w2sd <- sum((contract_years - contracts_mean)/ contracts_sd < 2)/contracts_n
contracts_w2sd
[1] 1
## Difference from empirical
contracts_w2sd - 0.95
[1] 0.05
4.What percent of the data lies within three standard deviations of
the mean?
## Within 3 sd
contracts_w3sd <- sum((contract_years - contracts_mean)/ contracts_sd < 3)/contracts_n
contracts_w3sd
[1] 1
## Difference from empirical
contracts_w3sd - 0.9973
[1] 0.0027
5.Draw a histogram
# Create histogram
hist(contract_years,xlab = "Years Left in Contract",col = "green",border = "red", xlim = c(0,8), ylim = c(0,225),
breaks = 5)

Question 3 Use the skills learned in case scenario
number 3 on one the following data sets. You may choose only one
dataset. They are both available in Canvas.
doubles_hit.csv
#This assigns the resulting data frame to the variable to doubles
doubles <- read.csv("C:/Users/auris/Downloads/doubles_hit.csv",header = TRUE, sep = ",")
# This assigns the values of the specified column to the variable contract_years
doubles_hits <- doubles$doubles_hit
# Mean - Average of the contract
doubles_mean <- mean(doubles_hits)
doubles_mean
[1] 23.55
# Median
doubles_median <- median(doubles_hits)
doubles_median
[1] 23.5
# Find number of observations
doubles_n <- length(doubles_hits)
doubles_n
[1] 100
# Find standard deviation
doubles_sd <- sd(doubles_hits)
doubles_sd
[1] 13.37371
2.- What percentage of the data lies within one standard deviation of
the mean?
doubles_w1sd <- sum((doubles_hits - doubles_mean)/doubles_sd < 1)/ doubles_n
# Percentage of observation within one standard deviation of the mean
doubles_w1sd
[1] 0.79
## Difference from empirical
doubles_w1sd - 0.68
[1] 0.11
- What percentage of the data lies within two standard deviations of
the mean?
## Within 2 sd
contracts_w2sd <- sum((doubles_hits - doubles_mean)/ doubles_sd < 2)/doubles_n
contracts_w2sd
[1] 1
## Difference from empirical
contracts_w2sd - 0.95
[1] 0.05
- What percent of the data lies within three standard deviations of
the mean?
## Within 2 sd
contracts_w3sd <- sum((doubles_hits - doubles_mean)/ doubles_sd < 3)/doubles_n
contracts_w3sd
[1] 1
## Difference from empirical
contracts_w3sd - 0.9973
[1] 0.0027
- Draw a histogram
# Create histogram
hist(doubles_hits,xlab = "Number of Doubles Hits",col = "green",border = "red", xlim = c(0,50), ylim = c(0,28),
breaks = 5)

LS0tDQp0aXRsZTogIkluLWNsYXNzIGFjdGl2aXR5ICM1KEhXKTogSW50cm9kdWN0aW9uIHRvIFIgZm9yIFNwb3J0cyBBbmFseXRpY3MsIFBhcnQgMiINCm91dHB1dDogaHRtbF9ub3RlYm9vaw0KLS0tDQoNCl9fX0dldHRpbmcgU3RhcnRlZCB3aXRoIFIsUGFydCAyX19fDQpMZXQgdXMgY29udGludWUgZ2V0dGluZyBzdGFydGVkIHdpdGggUiBhcyB3ZSBzdGFydCBkaXNjdXNzaW5nIGltcG9ydGFudCBzdGF0aXN0aWNhbCBjb25jZXB0cyBpbiBTcG9ydHMgQW5hbHl0aWNzLg0KDQpfX0Nhc2Utc2NlbmFyaW8gMV9fDQpUaGlzIGlzIHRoZSBmb3VydGggc2Vhc29uIG9mIG91dGZpZWxkZXIgTHVpcyBSb2JlcnQgd2l0aCB0aGUgQ2hpY2FnbyBXaGl0ZSBTb2Nrcy4gSWYgZHVyaW5nIHRoZSBmaXJzdCB0aHJlZSBzZWFzb25zIGhlIGhpdCAxMSwgMTMsIGFuZCAxMiBob21lIHJ1bnMsIGhvdyBtYW55IGRvZXMgaGUgbmVlZCBvbiB0aGlzIHNlYXNvbiBmb3IgaGlzIG92ZXJhbGwgYXZlcmFnZSB0byBiZSBhdCBsZWFzdCAyMD8NCg0KX19Tb2x1dGlvbl9fDQpHaXZlbiB0aGF0IHgxPTExLHgyPTEzLHgzPTEyDQoNCndlIHdhbnQgdG8gZmluZCB4NA0KIHN1Y2ggdGhhdCB0aGUgbWVhbiAoYXZlcmFnZSkgbnVtYmVyIG9mIGhvbWUtcnVucyBpcyB4wq8+PTIwDQoNCk5vdGljZSB0aGF0IGluIHRoaXMgY2FzZSBuPTQNCi4NCg0KQWNjb3JkaW5nIHRvIHRoZSBpbmZvcm1hdGlvbiBhYm92ZTogMjDDlzQ9MTErMTMrMTIreDQNCg0Kc28gd2hlbiB4ND00NA0KLCB0aGUgaG9tZS1ydW5zIGF2ZXJhZ2Ugd2lsbCBiZSAyMC4NCg0KDQpgYGB7cn0NCiMgSG9tZS1ydW5zIHNvIGZhcg0KSFJfYmVmb3JlIDwtIGMoMTEsIDEzLCAxMikNCiMgQXZlcmFnZSBOdW1iZXIgb2YgSG9tZS1ydW5zIHBlciBzZWFzb24gd2FudGVkDQp3YW50ZWRfSFIgPC0gMjANCiMgTnVtYmVyIG9mIHNlYXNvbnMNCm5fc2Vhc29ucyA8LSA0DQojIE5lZWRlZCBIb21lLXJ1bnMgb24gc2Vhc29uIDQNCnhfNCA8LSBuX3NlYXNvbnMqd2FudGVkX0hSIC0gc3VtKEhSX2JlZm9yZSkNCiMgTWluaW11bSBudW1iZXIgb2YgSG9tZS1ydW5zIG5lZWRlZCBieSBSb2JlcnQNCnhfNA0KYGBgDQpBY2NvcmRpbmcgdG8gdGhlIGNhbGN1bGF0aW9ucyBhYm92ZSwgUm9iZXJ0IG11c3QgaGl0IDQ0IGhvbWUtcnVucyBvciBiZXR0ZXIgb24gdGhpcyBzZWFzb24gdG8gZ2V0IGFuIGF2ZXJhZ2UgbnVtYmVyIG9mIGhvbWUtcnVucyBwZXIgc2Vhc29uIG9mIGF0IGxlYXN0IDIwLg0KDQpXZSBjb3VsZCBjb25maXJtIHRoaXMsIGJ5IHVzaW5nIHRoZSBmdW5jdGlvbiBtZWFuKCkgaW4gUg0KDQoNCmBgYHtyfQ0KIyBEaXZpc2lvbg0KIyBSb2JlcnQncyBwZXJmb3JtYW5jZQ0KUm9iZXJ0X0hScyA8LSBjKDExLCAxMywgMTIsNDQpDQojIEZpbmQgbWVhbg0KbWVhbihSb2JlcnRfSFJzKQ0KDQpgYGANCl9fUXVlc3Rpb24gM19fDQpVc2UgdGhlIHNraWxscyBsZWFybmVkIGluIGNhc2Ugc2NlbmFyaW8gbnVtYmVyIDMgb24gb25lIHRoZSBmb2xsb3dpbmcgZGF0YSBzZXRzLiBZb3UgbWF5IGNob29zZSBvbmx5IG9uZSBkYXRhc2V0LiBUaGV5IGFyZSBib3RoIGF2YWlsYWJsZSBpbiBDYW52YXMuDQoNCmRvdWJsZXNfaGl0LmNzdiBhbmQgdHJpcGxlc19oaXQuY3N2DQoNCmBgYHtyfQ0KIyBGaW5kIHN0YW5kYXJkIGRldmlhdGlvbg0Kc2QoUm9iZXJ0X0hScykNCg0KYGBgDQoNCmBgYHtyfQ0KIyBGaW5kIHRoZSBtYXhpbXVtIG51bWJlciBvZiBob21lLXJ1bnMgZHVyaW5nIHRoZSBmb3VyIHNlYXNvbnMgcGVyaW9kDQptYXgoUm9iZXJ0X0hScykNCmBgYA0KYGBge3J9DQojIEZpbmQgdGhlIG1pbmltdW0gbnVtYmVyIG9mIGhvbWUtcnVucyBkdXJpbmcgdGhlIGZvdXIgc2Vhc29ucyBwZXJpb2QNCm1pbihSb2JlcnRfSFJzKQ0KYGBgDQoNCldlIGNhbiBhbHNvIHVzZSB0aGUgc3VtbWFyeSgpIGZ1bmN0aW9uIHRvIGZpbmQgYmFzaWMgc3RhdGlzdGljcywgaW5jbHVkaW5nIHRoZSBtZWRpYW4hDQoNCmBgYHtyfQ0Kc3VtbWFyeShSb2JlcnRfSFJzKQ0KYGBgDQoNCl9fX1F1ZXN0aW9uIDFfX18NCk5vdywgeW91IG11c3QgY29tcGxldGUgdGhlIHByb2JsZW0gYmVsb3cgd2hpY2ggcmVwcmVzZW50cyBhIHNpbWlsYXIgY2FzZSBzY2VuYXJpby4gWW91IG1heSB1c2UgdGhlIHN0ZXBzIHRoYXQgd2UgZXhlY3V0ZWQgaW4gQ2FzZS1zY2VuYXJpbyAxIGFzIGEgdGVtcGxhdGUgZm9yIHlvdXIgc29sdXRpb24uDQoNClRoaXMgaXMgdGhlIHNpeHRoIHNlYXNvbiBvZiBvdXRmaWVsZGVyIEp1YW4gU290byBpbiB0aGUgbWFqb3JzLiBJZiBkdXJpbmcgdGhlIGZpcnN0IGZpdmUgc2Vhc29ucyBoZSByZWNlaXZlZCA3OSwgMTA4LDQxLDE0NSwgYW5kIDEzNSB3YWxrcywgaG93IG1hbnkgZG9lcyBoZSBuZWVkIG9uIHRoaXMgc2Vhc29uIGZvciBoaXMgb3ZlcmFsbCBudW1iZXIgb2Ygd2Fsa3MgcGVyIHNlYXNvbiB0byBiZSBhdCBsZWFzdCAxMDA/DQoNCmBgYHtyfQ0KIyBXYWxrcyBzbyBmYXINCldhbGtzX2JlZm9yZSA8LSBjKDc5LCAxMDgsNDEsMTQ1LCAxMzUpDQojIEF2ZXJhZ2UgTnVtYmVyIG9mIEhvbWUtcnVucyBwZXIgc2Vhc29uIHdhbnRlZA0Kd2FudGVkX3dhbGtzIDwtIDEwMA0KIyBOdW1iZXIgb2Ygc2Vhc29ucw0KSlNuX3NlYXNvbnMgPC0gNg0KIyBOZWVkZWQgd2Fsa3Mgb24gc2Vhc29uIDYNCnhfNiA8LSBKU25fc2Vhc29ucyp3YW50ZWRfd2Fsa3MgLSBzdW0oV2Fsa3NfYmVmb3JlKQ0KIyBNaW5pbXVtIG51bWJlciBvZiBXYWxrcyBuZWVkZWQgYnkgSnVhbiBTb3RvDQp4XzYNCmBgYA0KDQpfX19DYXNlLXNjZW5hcmlvIDJfX18NClRoZSBhdmVyYWdlIHNhbGFyeSBvZiAxMCBiYXNlYmFsbCBwbGF5ZXJzIGlzIDcyLDAwMCBkb2xsYXJzIGEgd2VlayBhbmQgdGhlIGF2ZXJhZ2Ugc2FsYXJ5IG9mIDQgc29jY2VyIHBsYXllcnMgaXMgODQsMDAwLiBGaW5kIHRoZSBtZWFuIHNhbGFyeSBvZiBhbGwgMTQgcHJvZmVzc2lvbmFsIHBsYXllcnMuDQoNCl9fU29sdXRpb25fXw0KV2UgY2FuIGVhc2lseSBmaW5kIHRoZSBqb2luZWQgbWVhbiBieSBhZGRpbmcgYm90aCBtZWFuIGFuZCBkaXZpZGluZyBieSB0aGUgdG90YWwgbnVtYmVyIG9mIHBlb3BsZS4NCg0KTGV0IG4xPTEwIGRlbm90ZSB0aGUgbnVtYmVyIG9mIGJhc2ViYWxsIHBsYXllcnMsIGFuZCB5MT03MjAwMCB0aGVpciBtZWFuIHNhbGFyeS4gTGV0IG4yPTQNCiB0aGUgbnVtYmVyIG9mIHNvY2NlciBwbGF5ZXJzIGFuZCB5Mj04NDAwMCB0aGVpciBtZWFuIHNhbGFyeS4gVGhlbiB0aGUgbWVhbiBzYWxhcnkgb2YgYWxsIDE2IGluZGl2aWR1YWxzIGlzOiAobjF4MStuMngyKS8objErbjIpDQoNCldlIGNhbiBjb21wdXRlIHRoaXMgaW4gUiBhcyBmb2xsb3dzOg0KDQpgYGB7cn0NCm5fMSA8LSAxMA0Kbl8yIDwtIDQNCnlfMSA8LSA3MjAwMA0KeV8yIDwtIDg0MDAwDQojIE1lYW4gc2FsYXJ5IG92ZXJhbGwNCnNhbGFyeV9hdmUgPC0gIChuXzEqeV8xICsgbl8yKnlfMikvKG5fMStuXzIpDQpzYWxhcnlfYXZlDQpgYGANCg0KX19fUXVlc3Rpb24gMl9fXw0KVGhlIGF2ZXJhZ2Ugc2FsYXJ5IG9mIDcgYmFza2V0YmFsbCBwbGF5ZXJzIGlzIDEwMiwwMDAgZG9sbGFycyBhIHdlZWsgYW5kIHRoZSBhdmVyYWdlIHNhbGFyeSBvZiA5IE5GTCBwbGF5ZXJzIGlzIDkxLDAwMC4gRmluZCB0aGUgbWVhbiBzYWxhcnkgb2YgYWxsIDE2IHByb2Zlc3Npb25hbCBwbGF5ZXJzLg0KDQpgYGB7cn0NCm5fMyA8LSA3DQpuXzQgPC0gOQ0KeV8zIDwtIDEwMjAwMA0KeV80IDwtIDkxMDAwDQojIE1lYW4gc2FsYXJ5IG92ZXJhbGwNCnNhbGFyeV9hdmVfYmFza19uZmwgPC0gIChuXzMqeV8zICsgbl80KnlfNCkvKG5fMytuXzQpDQpzYWxhcnlfYXZlX2Jhc2tfbmZsDQpgYGANCl9fX0Nhc2Utc2NlbmFyaW8gM19fXw0KVGhlIGZyZXF1ZW5jeSBkaXN0cmlidXRpb24gYmVsb3cgbGlzdHMgdGhlIG51bWJlciBvZiBhY3RpdmUgcGxheWVycyBpbiB0aGUgQmFyY2xheXMgUHJlbWllciBMZWFndWUgYW5kIHRoZSB0aW1lIGxlZnQgaW4gdGhlaXIgY29udHJhY3QuDQoNClllYXJzCU51bWJlciBvZiBwbGF5ZXJzDQo2CTI4DQo1CTcyDQo0CTIwMQ0KMwkxMDkNCjIJNTYNCjEJMzQNCg0KMS5GaW5kIHRoZSBtZWFuLHRoZSBtZWRpYW4gYW5kIHRoZSBzdGFuZGFyZCBkZXZpYXRpb24uDQoNCjIuV2hhdCBwZXJjZW50YWdlIG9mIHRoZSBkYXRhIGxpZXMgd2l0aGluIG9uZSBzdGFuZGFyZCBkZXZpYXRpb24gb2YgdGhlIG1lYW4/DQoNCjMuV2hhdCBwZXJjZW50YWdlIG9mIHRoZSBkYXRhIGxpZXMgd2l0aGluIHR3byBzdGFuZGFyZCBkZXZpYXRpb25zIG9mIHRoZSBtZWFuPw0KDQo0LldoYXQgcGVyY2VudCBvZiB0aGUgZGF0YSBsaWVzIHdpdGhpbiB0aHJlZSBzdGFuZGFyZCBkZXZpYXRpb25zIG9mIHRoZSBtZWFuPw0KDQo1LkRyYXcgYSBoaXN0b2dyYW0gdG8gaWxsdXN0cmF0ZSB0aGUgZGF0YS4NCg0KX19fU29sdXRpb25fX18NClRoZSBhbGxjb250cmFjdHMuY3N2IGZpbGUgY29udGFpbnMgYWxsIHRoZSBwbGF5ZXJz4oCZIGNvbnRyYWN0cyBsZW5ndGguIFdlIGNhbiByZWFkIHRoaXMgZmlsZSBpbiBSIHVzaW5nIHRoZSByZWFkLmNzdigpIGZ1bmN0aW9uLg0KDQpgYGB7cn0NCiNUaGlzIGFzc2lnbnMgdGhlIHJlc3VsdGluZyBkYXRhIGZyYW1lIHRvIHRoZSB2YXJpYWJsZSB0byAgY29udHJhY3RfbGVuZ3RoDQpjb250cmFjdF9sZW5ndGggPC0gcmVhZC5jc3YoIkM6L1VzZXJzL2F1cmlzL0Rvd25sb2Fkcy9hbGxjb250cmFjdHMuY3N2IixoZWFkZXIgPSBUUlVFLCBzZXAgPSAiLCIpDQojIFRoaXMgYXNzaWducyB0aGUgdmFsdWVzIG9mIHRoZSBzcGVjaWZpZWQgY29sdW1uIHRvIHRoZSB2YXJpYWJsZSBjb250cmFjdF95ZWFycw0KY29udHJhY3RfeWVhcnMgPC0gY29udHJhY3RfbGVuZ3RoJHllYXJzDQoNCg0KYGBgDQoNCk1ha2UgY29tbWVudHMgYWJvdXQgdGhlIGNvZGUgd2UganVzdCByYW4gYWJvdmUuDQoNClRvIGZpbmQgdGhlIG1lYW4gYW5kIHRoZSBzdGFuZGFyZCBkZXZpYXRpb24NCg0KYGBge3J9DQojIE1lYW4gLSAgQXZlcmFnZSBvZiB0aGUgY29udHJhY3QNCmNvbnRyYWN0c19tZWFuICA8LSBtZWFuKGNvbnRyYWN0X3llYXJzKQ0KY29udHJhY3RzX21lYW4NCmBgYA0KDQpgYGB7cn0NCiMgTWVkaWFuDQpjb250cmFjdHNfbWVkaWFuIDwtIG1lZGlhbihjb250cmFjdF95ZWFycykNCmNvbnRyYWN0c19tZWRpYW4NCmBgYA0KDQpgYGB7cn0NCiMgRmluZCBudW1iZXIgb2Ygb2JzZXJ2YXRpb25zDQpjb250cmFjdHNfbiA8LSBsZW5ndGgoY29udHJhY3RfeWVhcnMpDQojIEZpbmQgc3RhbmRhcmQgZGV2aWF0aW9uDQpjb250cmFjdHNfc2QgPC0gc2QoY29udHJhY3RfeWVhcnMpDQpgYGANCg0KMi4tIFdoYXQgcGVyY2VudGFnZSBvZiB0aGUgZGF0YSBsaWVzIHdpdGhpbiBvbmUgc3RhbmRhcmQgZGV2aWF0aW9uIG9mIHRoZSBtZWFuPw0KDQpgYGB7cn0NCmNvbnRyYWN0c193MXNkIDwtIHN1bSgoY29udHJhY3RfeWVhcnMgLSBjb250cmFjdHNfbWVhbikvY29udHJhY3RzX3NkIDwgMSkvIGNvbnRyYWN0c19uDQojIFBlcmNlbnRhZ2Ugb2Ygb2JzZXJ2YXRpb24gd2l0aGluIG9uZSBzdGFuZGFyZCBkZXZpYXRpb24gb2YgdGhlIG1lYW4NCmNvbnRyYWN0c193MXNkDQpgYGANCg0KYGBge3J9DQojIyBEaWZmZXJlbmNlIGZyb20gZW1waXJpY2FsIA0KY29udHJhY3RzX3cxc2QgLSAwLjY4DQpgYGANCjMuV2hhdCBwZXJjZW50YWdlIG9mIHRoZSBkYXRhIGxpZXMgd2l0aGluIHR3byBzdGFuZGFyZCBkZXZpYXRpb25zIG9mIHRoZSBtZWFuPw0KDQpgYGB7cn0NCiMjIFdpdGhpbiAyIHNkDQpjb250cmFjdHNfdzJzZCA8LSBzdW0oKGNvbnRyYWN0X3llYXJzIC0gY29udHJhY3RzX21lYW4pLyBjb250cmFjdHNfc2QgPCAyKS9jb250cmFjdHNfbg0KY29udHJhY3RzX3cyc2QNCmBgYA0KDQpgYGB7cn0NCiMjIERpZmZlcmVuY2UgZnJvbSBlbXBpcmljYWwgDQpjb250cmFjdHNfdzJzZCAtIDAuOTUNCmBgYA0KDQo0LldoYXQgcGVyY2VudCBvZiB0aGUgZGF0YSBsaWVzIHdpdGhpbiB0aHJlZSBzdGFuZGFyZCBkZXZpYXRpb25zIG9mIHRoZSBtZWFuPw0KDQpgYGB7cn0NCiMjIFdpdGhpbiAzIHNkIA0KY29udHJhY3RzX3czc2QgPC0gc3VtKChjb250cmFjdF95ZWFycyAtIGNvbnRyYWN0c19tZWFuKS8gY29udHJhY3RzX3NkIDwgMykvY29udHJhY3RzX24NCmNvbnRyYWN0c193M3NkDQpgYGANCg0KYGBge3J9DQojIyBEaWZmZXJlbmNlIGZyb20gZW1waXJpY2FsIA0KY29udHJhY3RzX3czc2QgLSAwLjk5NzMNCmBgYA0KDQo1LkRyYXcgYSBoaXN0b2dyYW0NCg0KYGBge3J9DQojIENyZWF0ZSBoaXN0b2dyYW0NCmhpc3QoY29udHJhY3RfeWVhcnMseGxhYiA9ICJZZWFycyBMZWZ0IGluIENvbnRyYWN0Iixjb2wgPSAiZ3JlZW4iLGJvcmRlciA9ICJyZWQiLCB4bGltID0gYygwLDgpLCB5bGltID0gYygwLDIyNSksDQogICBicmVha3MgPSA1KQ0KYGBgDQoNCl9fUXVlc3Rpb24gM19fDQpVc2UgdGhlIHNraWxscyBsZWFybmVkIGluIGNhc2Ugc2NlbmFyaW8gbnVtYmVyIDMgb24gb25lIHRoZSBmb2xsb3dpbmcgZGF0YSBzZXRzLiBZb3UgbWF5IGNob29zZSBvbmx5IG9uZSBkYXRhc2V0LiBUaGV5IGFyZSBib3RoIGF2YWlsYWJsZSBpbiBDYW52YXMuDQoNCmRvdWJsZXNfaGl0LmNzdiANCg0KDQpgYGB7cn0NCiNUaGlzIGFzc2lnbnMgdGhlIHJlc3VsdGluZyBkYXRhIGZyYW1lIHRvIHRoZSB2YXJpYWJsZSB0byBkb3VibGVzDQpkb3VibGVzIDwtIHJlYWQuY3N2KCJDOi9Vc2Vycy9hdXJpcy9Eb3dubG9hZHMvZG91Ymxlc19oaXQuY3N2IixoZWFkZXIgPSBUUlVFLCBzZXAgPSAiLCIpDQoNCmRvdWJsZXNfaGl0cyA8LSBkb3VibGVzJGRvdWJsZXNfaGl0DQpgYGANCg0KDQpgYGB7cn0NCiMgTWVhbiAtICBBdmVyYWdlIG9mIGRvdWJsZXMgaGl0cw0KZG91Ymxlc19tZWFuICA8LSBtZWFuKGRvdWJsZXNfaGl0cykNCmRvdWJsZXNfbWVhbg0KYGBgDQpgYGB7cn0NCiMgTWVkaWFuDQpkb3VibGVzX21lZGlhbiA8LSBtZWRpYW4oZG91Ymxlc19oaXRzKQ0KZG91Ymxlc19tZWRpYW4NCmBgYA0KYGBge3J9DQojIEZpbmQgbnVtYmVyIG9mIG9ic2VydmF0aW9ucw0KZG91Ymxlc19uIDwtIGxlbmd0aChkb3VibGVzX2hpdHMpDQpkb3VibGVzX24NCiMgRmluZCBzdGFuZGFyZCBkZXZpYXRpb24NCmRvdWJsZXNfc2QgPC0gc2QoZG91Ymxlc19oaXRzKQ0KZG91Ymxlc19zZA0KYGBgDQoNCjIuLSBXaGF0IHBlcmNlbnRhZ2Ugb2YgdGhlIGRhdGEgbGllcyB3aXRoaW4gb25lIHN0YW5kYXJkIGRldmlhdGlvbiBvZiB0aGUgbWVhbj8NCg0KYGBge3J9DQpkb3VibGVzX3cxc2QgPC0gc3VtKChkb3VibGVzX2hpdHMgLSBkb3VibGVzX21lYW4pL2RvdWJsZXNfc2QgPCAxKS8gZG91Ymxlc19uDQojIFBlcmNlbnRhZ2Ugb2Ygb2JzZXJ2YXRpb24gd2l0aGluIG9uZSBzdGFuZGFyZCBkZXZpYXRpb24gb2YgdGhlIG1lYW4NCmRvdWJsZXNfdzFzZA0KYGBgDQpgYGB7cn0NCiMjIERpZmZlcmVuY2UgZnJvbSBlbXBpcmljYWwgDQpkb3VibGVzX3cxc2QgLSAwLjY4DQpgYGANCg0KDQozLiBXaGF0IHBlcmNlbnRhZ2Ugb2YgdGhlIGRhdGEgbGllcyB3aXRoaW4gdHdvIHN0YW5kYXJkIGRldmlhdGlvbnMgb2YgdGhlIG1lYW4/DQoNCg0KDQpgYGB7cn0NCiMjIFdpdGhpbiAyIHNkDQpjb250cmFjdHNfdzJzZCA8LSBzdW0oKGRvdWJsZXNfaGl0cyAtIGRvdWJsZXNfbWVhbikvIGRvdWJsZXNfc2QgPCAyKS9kb3VibGVzX24NCmNvbnRyYWN0c193MnNkDQpgYGANCg0KYGBge3J9DQojIyBEaWZmZXJlbmNlIGZyb20gZW1waXJpY2FsIA0KY29udHJhY3RzX3cyc2QgLSAwLjk1DQpgYGANCg0KNC4gV2hhdCBwZXJjZW50IG9mIHRoZSBkYXRhIGxpZXMgd2l0aGluIHRocmVlIHN0YW5kYXJkIGRldmlhdGlvbnMgb2YgdGhlIG1lYW4/DQoNCmBgYHtyfQ0KIyMgV2l0aGluIDMgc2QNCmNvbnRyYWN0c193M3NkIDwtIHN1bSgoZG91Ymxlc19oaXRzIC0gZG91Ymxlc19tZWFuKS8gZG91Ymxlc19zZCA8IDMpL2RvdWJsZXNfbg0KY29udHJhY3RzX3czc2QNCmBgYA0KDQpgYGB7cn0NCiMjIERpZmZlcmVuY2UgZnJvbSBlbXBpcmljYWwgDQpjb250cmFjdHNfdzNzZCAtIDAuOTk3Mw0KYGBgDQoNCjUuIERyYXcgYSBoaXN0b2dyYW0NCg0KYGBge3J9DQojIENyZWF0ZSBoaXN0b2dyYW0NCmhpc3QoZG91Ymxlc19oaXRzLHhsYWIgPSAiTnVtYmVyIG9mIERvdWJsZXMgSGl0cyIsY29sID0gImdyZWVuIixib3JkZXIgPSAicmVkIiwgeGxpbSA9IGMoMCw1MCksIHlsaW0gPSBjKDAsMjgpLA0KICAgYnJlYWtzID0gNSkNCmBgYA0KDQo=