※ 当サイトは、アフィリエイト広告を利用しています。

データで見るメンフィス・グリズリーズの特徴と傾向【NBA2008-09 レギュラー・シーズン】

記事内に広告が含まれています。
スポンサーリンク
スポンサーリンク

※参考<統計ソフトRに入力するコマンド>

 統計ソフトRのインストール手順をまとめた記事も作成していますので、よろしければご参考ください。

library(BasketballAnalyzeR)
library(gridExtra)
library(dplyr)
Pbox0809 <- read.csv(file="Pbox_0809.csv")
dts.PbP.0809 <- read.csv(file="PbP_0809.csv")
PbP0809 <- PbPmanipulation(dts.PbP.0809)

# Bubble plot of the players
Pbox0809b <- subset(Pbox0809, MIN>=500)
data0809b <- subset(Pbox0809b, Team=="Memphis Grizzlies")
attach(data0809b)
X2 <- data.frame(P=Player, P2M=P2M/GP, P3M=P3M/GP, FTp, AS=(P2A+P3A+FTA)/GP)
detach(data0809b)
labs1 <- c("2-point shots made per Game", "3-point shots made per Game", "Free throws (% made)", "Total shots attempted per Game")
bubbleplot(X2, id="P", x="P2M", y="P3M", col="FTp", size="AS", labels=labs1, title="Bubble plot of Memphis Grizzlies' players: Shooting stats and shots attempted (NBA 2008 - 2009 Regular season)", text.size=3.5, mx = mean(Pbox0809b$P2M/Pbox0809b$GP), my = mean(Pbox0809b$P3M/Pbox0809b$GP))

attach(data0809b)
Y2 <- data.frame(P=Player, DREB=DREB/GP, STL=STL/GP, BLK=BLK/GP, PM=PM/GP)
detach(data0809b)
labs2 <- c("Defensive Rebounds per Game", "Blocks per Game", "Plus-Minus per Game", "Steals per Game")
bubbleplot(Y2, id="P", x="DREB", y="BLK", col="PM", size="STL", labels=labs2, title="Bubble plot of Memphis Grizzlies' players: Defensive stats and Plus-Minus (NBA 2008 - 2009 Regular season)", text.size=3.5, mx = mean(Pbox0809b$DREB/Pbox0809b$GP), my = mean(Pbox0809b$BLK/Pbox0809b$GP))

# Radar chart of the players
Pbox0809r <- subset(Pbox0809, MIN>=500)
attach(Pbox0809r)
T <- data.frame(P2M,P3M, FTM, REB=OREB+DREB, AST, STL, BLK)/MIN
detach(Pbox0809r)
T2 <- data.frame(Team=Pbox0809r$Team, Player=Pbox0809r$Player, T)
listplots <- radialprofile(data=T2[3:9], title=T2$Player, std=TRUE)
listplotsT <- listplots[T2$Team=="Memphis Grizzlies"]
grid.arrange(grobs=listplotsT[1:12], ncol=4)
grid.arrange(grobs=listplotsT[13:24], ncol=4)

# Variability diagram of the traditional stats
Pbox0809v <- subset(Pbox0809, Team=="Memphis Grizzlies" & MIN>=500)
vrb <- variability(data=Pbox0809v, data.var=c("P2M", "P3M", "FTM", "OREB", "DREB","AST","STL","BLK","TOV"), size.var=c("MIN"))
plot(vrb, title="Variability diagram of the traditional stats, Memphis Grizzlies' players (NBA 2008 - 2009 Regular season)")

# Shot chart of the team
PbP0809sc <- subset(PbP0809, data_set!="2008-09 Playoffs" & team=="MEM")
PbP0809sc$xx <- PbP0809sc$original_x/-10
PbP0809sc$yy <- PbP0809sc$original_y/10-41.75
shotchart(data=PbP0809sc, x="xx", y="yy", z="playlength", num.sect=5, type="sectors", scatter=FALSE, result="result")
shotchart(data=PbP0809sc, x="xx", y="yy", type="density-hexbin", nbins=50, palette="bwr")

# Density estimation of the field shots
data0809d <- subset(PbP0809, data_set!="2008-09 Playoffs" & result!="" & shot_distance!="" & team=="MEM")
densityplot(data=data0809d, shot.type="field", var="shot_distance", best.score=TRUE, title="Density estimation of the field shots of Memphis Grizzlies, with respect to shot distance (NBA 2008 - 2009 Regular Season)")
densityplot(data=data0809d, shot.type="field", var="totalTime", best.score=TRUE, title="Density estimation of the field shots of Memphis Grizzlies, with respect to total time (NBA 2008 - 2009 Regular Season)")
densityplot(data=data0809d, shot.type="field", var="playlength", best.score=TRUE, title="Density estimation of the field shots of Memphis Grizzlies, with respect to play length (NBA 2008 - 2009 Regular Season)")

# Expected points of the teams
data0809t <- subset(PbP0809, data_set!="2008-09 Playoffs" & result!="" & shot_distance!="" & team=="MEM")
data0809o <- subset(PbP0809, data_set!="2008-09 Playoffs" & result!="" & shot_distance!="" & oppTeam=="MEM")
data0809t <- mutate(data0809t, player = "Memphis Grizzlies")
data0809o <- mutate(data0809o, player = "Opponent teams")
data0809TO <- bind_rows(data0809t, data0809o)
pl <- c("Memphis Grizzlies","Opponent teams")
mypal <- colorRampPalette(c("red","blue"))
expectedpts(data0809TO, players=pl, col.team="gray", palette=mypal, col.hline="transparent", var="shot_distance", xlab="Shot distance", title="Expected points of Memphis Grizzlies and opponent teams, with respect to shot distance (NBA 2008 - 2009 Regular Season)")
expectedpts(data0809TO, bw=1500, players=pl, col.team="gray", palette=mypal, col.hline="transparent", var="totalTime", xlab="Total time", title="Expected points of Memphis Grizzlies and opponent teams, with respect to total time (NBA 2008 - 2009 Regular Season)")
expectedpts(data0809TO, players=pl, col.team="gray", palette=mypal, col.hline="transparent", var="playlength", xlab="Play length", title="Expected points of Memphis Grizzlies and opponent teams, with respect to play length (NBA 2008 - 2009 Regular Season)")
write.csv(data0809TO, "data0809TO.csv")

# Network of assists
PbP0809an <- subset(PbP0809, data_set!="2008-09 Playoffs" & team=="MEM")
PbP0809AN <- PbP0809an[!(PbP0809an$event_type=="shot" & PbP0809an$result=="missed"),]
netdataAN <- assistnet(PbP0809AN)
plot(netdataAN, layout="circle", edge.thr=20, node.col="FGPTS", node.size="ASTPTS")
TABan <- netdataAN$assistTable
Xan <- netdataAN$nodeStats
names(Xan)[1] <- "Player"
dataAN <- merge(Xan, Pbox0809, by="Player")
dataANsp <- subset(dataAN, Team=="Memphis Grizzlies")
mypal <- colorRampPalette(c("blue", "yellow", "red"))
scatterplot(dataANsp, data.var=c("ASTPTS", "FGPTS"), z.var="MIN", labels=dataANsp$Player, palette=mypal, repel_labels=TRUE, title="Scatter plot of Memphis Grizzlies' players: ASTPTS and FGPTS (NBA 2008 - 2009 Regular Season)")
selan <- which(dataAN$MIN>1500 & dataAN$Team=="Memphis Grizzlies")
tabAN <- TABan[selan, selan]
no.pl <- nrow(tabAN)
pR <- pM <- vector(no.pl, mode="list")
GiniM <- array(NA, no.pl)
GiniR <- array(NA, no.pl)
for (pl in 1:no.pl){
      ineqplM <- inequality(tabAN[pl,], npl=no.pl)
      GiniM[pl] <- ineqplM$Gini
      ineqplR <- inequality(tabAN[,pl], npl=no.pl)
      GiniR[pl] <- ineqplR$Gini
      title <- rownames(tabAN)[pl]
      pM[[pl]] <- plot(ineqplM, title=title)
      pR[[pl]] <- plot(ineqplR, title=title)
      }

grid.arrange(grobs=pM, nrow=2)
grid.arrange(grobs=pR, nrow=2)
write.csv(Xan, "Xan.csv")
write.csv(tabAN, "tabAN.csv")

# Shot chart of the opponent teams
PbP0809sco <- subset(PbP0809, data_set!="2008-09 Playoffs" & oppTeam=="MEM")
PbP0809sco$xx <- PbP0809sco$original_x/-10
PbP0809sco$yy <- PbP0809sco$original_y/10-41.75
shotchart(data=PbP0809sco, x="xx", y="yy", z="playlength", num.sect=5, type="sectors", scatter=FALSE, result="result")
shotchart(data=PbP0809sco, x="xx", y="yy", type="density-hexbin", nbins=50, palette="bwr")
write.csv(PbP0809sco, "PbP0809sco.csv")

# Density estimation of the field shots of the opponent teams
data0809do <- subset(PbP0809, data_set!="2008-09 Playoffs" & result!="" & shot_distance!="" & oppTeam=="MEM")
densityplot(data=data0809do, shot.type="field", var="shot_distance", best.score=TRUE, title="Density estimation of the field shots of Memphis Grizzlies' opponents, with respect to shot distance (NBA 2008 - 2009 Regular Season)")
write.csv(data0809do, "data0809do.csv")

⇐ 2007-08 |🏀| 2009-10 ⇒

※データ分析を実践する際に参考にしている書籍『Basketball Data Science: With Applications in R』の紹介記事も書いていますので、よろしければ下記よりご確認ください。

スポンサーリンク
スポンサーリンク
スポンサーリンク
** データ分析を実践する際に参考にしている書籍です **

Paola Zuccolotto and Marica Manisera (2020), Basketball Data Science – with Applications in R. Chapman and Hall/CRC. ISBN 9781138600799.

TeamsMemphis Grizzlies

X(旧Twitter)アカウントあります。コメント等があればhttps://x.com/basketrashtalkへお願いします。

Kaneshiroをフォローする
タイトルとURLをコピーしました