※参考<統計ソフトRに入力するコマンド>
統計ソフトRのインストール手順をまとめた記事も作成していますので、よろしければご参考ください。
library(BasketballAnalyzeR)
library(gridExtra)
Tbox9899 <- read.csv(file="Tbox_9899.csv")
Obox9899 <- read.csv(file="Obox_9899.csv")
Tadd9899 <- read.csv(file="Tadd_9899.csv")
Pbox9899 <- read.csv(file="Pbox_9899.csv")
# Possessions, PACE, Offensive/Defensive Ratings, Four Factors
fourfactors9899 <- fourfactors(Tbox9899, Obox9899)
Playoff <- Tadd9899$Playoff
fourfactors9899PO <- data.frame(fourfactors9899, Playoff)
fourfactors9899PO
# Scatter plot of PACE, Offensive/Defensive Ratings, Four Factors
ggplot(data=fourfactors9899PO, aes(x=PACE.Off, y=PACE.Def, color = Playoff, label=Team)) +
geom_point() +
ggrepel::geom_text_repel(aes(label = Team))+
geom_vline(xintercept =mean(fourfactors9899PO$PACE.Off))+
geom_hline(yintercept =mean(fourfactors9899PO$PACE.Def))+
labs(title = "PACE - NBA teams (NBA 1998 - 1999 Regular Season)")+
labs(x = "Pace (Possessions per minute) of the Team") +
labs(y = "Pace (Possessions per minute) of the Opponents")
ggplot(data=fourfactors9899PO, aes(x=ORtg, y=DRtg, color = Playoff, label=Team)) +
geom_point() +
ggrepel::geom_text_repel(aes(label = Team))+
geom_vline(xintercept =mean(fourfactors9899PO$ORtg))+
geom_hline(yintercept =mean(fourfactors9899PO$DRtg))+
labs(title = "ORtg and DRtg - NBA teams (NBA 1998 - 1999 Regular Season)")+
labs(x = "Offensive Rating of the Team (ORtg)") +
labs(y = "Offensive Rating of the Opponents (DRtg)")
ggplot(data=fourfactors9899PO, aes(x=F1.Off, y=F1.Def, color = Playoff, label=Team)) +
geom_point() +
ggrepel::geom_text_repel(aes(label = Team))+
geom_vline(xintercept =mean(fourfactors9899PO$F1.Off))+
geom_hline(yintercept =mean(fourfactors9899PO$F1.Def))+
labs(title = "Factor 1: eFG% - NBA teams (NBA 1998 - 1999 Regular Season)")+
labs(x = "eFG% (Offense)") +
labs(y = "eFG% (Defense)")
ggplot(data=fourfactors9899PO, aes(x=F2.Off, y=F2.Def, color = Playoff, label=Team)) +
geom_point() +
ggrepel::geom_text_repel(aes(label = Team))+
geom_vline(xintercept =mean(fourfactors9899PO$F2.Off))+
geom_hline(yintercept =mean(fourfactors9899PO$F2.Def))+
labs(title = "Factor 2: TO Ratio - NBA teams (NBA 1998 - 1999 Regular Season)")+
labs(x = "TO Ratio (Offense)") +
labs(y = "TO Ratio (Defense)")
ggplot(data=fourfactors9899PO, aes(x=F3.Off, y=F3.Def, color = Playoff, label=Team)) +
geom_point() +
ggrepel::geom_text_repel(aes(label = Team))+
geom_vline(xintercept =mean(fourfactors9899PO$F3.Off))+
geom_hline(yintercept =mean(fourfactors9899PO$F3.Def))+
labs(title = "Factor 3: REB% - NBA teams (NBA 1998 - 1999 Regular Season)")+
labs(x = "REB% (Offense)") +
labs(y = "REB% (Defense)")
ggplot(data=fourfactors9899PO, aes(x=F4.Off, y=F4.Def, color = Playoff, label=Team)) +
geom_point() +
ggrepel::geom_text_repel(aes(label = Team))+
geom_vline(xintercept =mean(fourfactors9899PO$F4.Off))+
geom_hline(yintercept =mean(fourfactors9899PO$F4.Def))+
labs(title = "Factor 4: FT Rate - NBA teams (NBA 1998 - 1999 Regular Season)")+
labs(x = "FT Rate (Offense)") +
labs(y = "FT Rate (Defense)")
# Correlation matrix
data9899c <- subset(Pbox9899, MIN>=500*0.6)
attach(data9899c)
X <- data.frame(P2M, P3M, FTM, REB=(OREB+DREB), AST, STL, BLK, TOV)/MIN
detach(data9899c)
corrmatrix <- corranalysis(X[,1:8], threshold=0.4)
plot(corrmatrix)
attach(fourfactors9899)
Y <- data.frame(PACE.Off, ORtg, eFGp.Off=F1.Off, TOR.Off=F2.Off, REBp.Off=F3.Off, FTR.Off=F4.Off, PACE.Def, DRtg, eFGp.Def=F1.Def, TOR.Def=F2.Def, REBp.Def=F3.Def, FTR.Def=F4.Def)
detach(fourfactors9899)
corrmatrixY <- corranalysis(Y[,1:12], threshold=0.4)
plot(corrmatrixY)
# Bubble plot of NBA teams
attach(Tbox9899)
X2 <- data.frame(T=Team, P2p, P3p, FTp, AS=P2A+P3A+FTA)
detach(Tbox9899)
labs1 <- c("2-point shots (% made)", "3-point shots (% made)", "free throws (% made)", "Total shots attempted")
bubbleplot(X2, id="T", x="P2p", y="P3p", col="FTp", size="AS", labels=labs1, title="Bubble plot of NBA teams: Shooting percentage and shots attempted (NBA 1998 - 1999 Regular season)", text.size=3.5)
attach(Tbox9899)
Y2 <- data.frame(T=Team, DREB=DREB/GP, STL=STL/GP, BLK=BLK/GP, PM=PM/GP)
detach(Tbox9899)
labs2 <- c("Defensive Rebounds per Game", "Blocks per Game", "Plus-Minus per Game", "Steals per Game")
bubbleplot(Y2, id="T", x="DREB", y="BLK", col="PM", size="STL", labels=labs2, title="Bubble plot of NBA teams: Defensive stats and Plus-Minus (NBA 1998 - 1999 Regular season)", text.size=3.5)
# Radar chart of NBA teams
attach(Tbox9899)
T <- data.frame(P2M,P3M, FTM, REB=OREB+DREB, AST, STL, BLK)/MIN
detach(Tbox9899)
radialprofile(data=T, title=Tbox9899$Team, std=TRUE)
listplots <- radialprofile(data=T, title=Tbox9899$Team, std=TRUE)
grid.arrange(grobs=listplots[1:15], ncol=5)
grid.arrange(grobs=listplots[16:30], ncol=5)
# Non-hierarchical clustering - K-means
FF9899 <- fourfactors(Tbox9899, Obox9899)
OD.Rtg <- FF9899$ORtg/FF9899$DRtg
F1.r <- FF9899$F1.Off/FF9899$F1.Def
F2.r <- FF9899$F2.Def/FF9899$F2.Off
F3.Off <- FF9899$F3.Off
F3.Def <- FF9899$F3.Def
P3M <- Tbox9899$P3M
STL.r <- Tbox9899$STL/Obox9899$STL
data9899k <- data.frame(OD.Rtg, F1.r, F2.r, F3.Off, F3.Def, P3M, STL.r)
set.seed(29)
kclu1 <- kclustering(data9899k)
plot(kclu1)
set.seed(29)
kclu2 <- kclustering(data9899k, labels=Tbox9899$Team, k=6)
plot(kclu2)
kclu2
kclu2.PO <- table(kclu2$Subjects$Cluster, Tadd9899$Playoff)
kclu2.W <- tapply(Tbox9899$W, kclu2$Subjects$Cluster, mean)
Xbar <- data.frame(cluster=c(1:6), No=kclu2.PO[,1], Yes=kclu2.PO[,2], W=kclu2.W)
barline(data=Xbar, id="cluster", bars=c("Yes", "No"), labels.bars=c("Playoff: YES", "Playoff: NO"), line="W", label.line="average wins", decreasing=FALSE)
cluster <- as.factor(kclu2$Subjects$Cluster)
Xbubble <- data.frame(Team=Tbox9899$Team, PTS=Tbox9899$PTS, PTS.Opp=Obox9899$PTS, cluster, OD.Rtg=data9899k$OD.Rtg)
labs <- c("PTS", "PTS.Opp", "cluster", "OD.Rtg")
bubbleplot(Xbubble, id="Team", x="PTS", y="PTS.Opp", col="cluster", size="OD.Rtg", labels=labs, title="Bubble plot of NBA teams: PTS, Opponent PTS, Cluster and OD.Rtg (NBA 1998 - 1999 Regular season)", text.size=3.0)
# Gini index with respect to PTS and AST
no.teams <- nrow(Tbox9899)
GINI_PTS <- array(0, no.teams)
for (k in 1:no.teams) {
Teamk <- Tbox9899$Team[k]
Pbox9899.sel <- subset(Pbox9899, Team==Teamk)
index1 <- inequality(Pbox9899.sel$PTS, npl=8)
GINI_PTS[k] <- index1$Gini
}
GINI_AST <- array(0, no.teams)
for (k in 1:no.teams) {
Teamk <- Tbox9899$Team[k]
Pbox9899.sel <- subset(Pbox9899, Team==Teamk)
index2 <- inequality(Pbox9899.sel$AST, npl=6)
GINI_AST[k] <- index2$Gini
}
dts <- data.frame(Team=Tbox9899$Team, GINI_PTS, GINI_AST, PTS=Tbox9899$PTS, AST=Tbox9899$AST, Playoff=Tadd9899$Playoff)
ggplot(data=dts, aes(x=GINI_PTS, y=GINI_AST, color = Playoff, label=Tbox9899$Team)) +
geom_point() +
ggrepel::geom_text_repel(aes(label = Tbox9899$Team))+
geom_vline(xintercept =mean(dts$GINI_PTS))+
geom_hline(yintercept =mean(dts$GINI_AST))+
labs(title = "Scatter plot of NBA teams: Gini index for PTS and AST (NBA 1998 - 1999 Regular season)")+
labs(x = "GINI_PTS") +
labs(y = "GINI_AST")
# MDS Map of NBA Players
attach(Pbox9899)
data9899m <- data.frame(P2M, P3M, FTM, REB=(OREB+DREB), AST, STL, BLK)/MIN
detach(Pbox9899)
data9899m <- subset(data9899m, Pbox9899$MIN>=1500*0.6)
id <- Pbox9899$Player[Pbox9899$MIN>=1500*0.6]
mds <- MDSmap(data9899m)
selp <- which(id=="Shaquille O'Neal" | id=="Dee Brown" | id=="Shawn Kemp" | id=="Danny Fortson" | id=="Mark Jackson" | id=="Kendall Gill" | id=="Shawn Bradley")
plot(mds, labels=id, subset=selp, col.subset="tomato")
plot(mds, labels=id, subset=selp, col.subset="tomato", zoom=c(-2.5,2.5,-2,2))
plot(mds, z.var=c("P2M", "P3M", "FTM", "REB", "AST", "STL", "BLK"), contour=TRUE, palette=topo.colors)
# Hierarchical clustering - Ward
attach(Pbox9899)
data9899w <- data.frame(PTS, P2M, P3M, REB=(OREB+DREB), AST, TOV, STL, BLK)/MIN
detach(Pbox9899)
data9899w <- subset(data9899w, Pbox9899$MIN>=1800*0.6)
ID <- Pbox9899$Player[Pbox9899$MIN>=1800*0.6]
hclu1 <- hclustering(data9899w)
plot(hclu1)
hclu2 <- hclustering(data9899w, labels=ID, k=7)
plot(hclu2, profiles=TRUE)
plot(hclu2, rect=TRUE, colored.branches=TRUE, cex.labels=0.2)
※データ分析を実践する際に参考にしている書籍『Basketball Data Science: With Applications in R』の紹介記事も書いていますので、よろしければ下記よりご確認ください。