Skip to content

Commit

Permalink
Merge pull request #7 from bdilday/feature-sample-retrosheet-data
Browse files Browse the repository at this point in the history
Feature sample retrosheet data
  • Loading branch information
bdilday authored Mar 11, 2018
2 parents b00cc50 + cabc7b7 commit 6819276
Show file tree
Hide file tree
Showing 4 changed files with 71 additions and 9 deletions.
3 changes: 3 additions & 0 deletions NAMESPACE
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
# Generated by roxygen2: do not edit by hand

export(mnre_dim_and_class_to_index)
export(mnre_example_retrosheet_event_data)
export(mnre_expand_matrix)
export(mnre_fit)
export(mnre_fit_sparse)
Expand All @@ -14,5 +15,7 @@ export(mnre_step_sparse)
export(nd_min_fun)
import(Matrix)
importFrom(Rcpp,sourceCpp)
importFrom(magrittr,"%$%")
importFrom(magrittr,"%<>%")
importFrom(magrittr,"%>%")
useDynLib(mnre)
73 changes: 66 additions & 7 deletions R/main.R
Original file line number Diff line number Diff line change
Expand Up @@ -47,15 +47,15 @@ mnre_simulate_ev_data <- function(nlim=1000, year=2016, OBP=FALSE) {

dfX$y <- dfX$outcome

glf <- lme4::glFormula(y ~ (1|BAT_ID) + (1|PIT_ID) + (1|HOME_TEAM_ID),
glf <- lme4::glFormula(y ~ (1|bat_id) + (1|pit_id) + (1|home_team_id),
data=dfX, family='binomial')
#glf <- lme4::glFormula(y ~ (1|PIT_ID) + (1|BAT_ID),
#glf <- lme4::glFormula(y ~ (1|pit_id) + (1|bat_id),
# data=dfX, family='binomial')

dfX <- dfX %>% dplyr::mutate(pid=as.integer(as.factor(PIT_ID)))
dfX <- dfX %>% dplyr::mutate(bid=as.integer(as.factor(BAT_ID)))
dfX <- dfX %>% dplyr::mutate(pid=as.integer(as.factor(pit_id)))
dfX <- dfX %>% dplyr::mutate(bid=as.integer(as.factor(bat_id)))

dfX <- dfX %>% dplyr::mutate(sid=as.integer(as.factor(HOME_TEAM_ID)))
dfX <- dfX %>% dplyr::mutate(sid=as.integer(as.factor(home_team_id)))
dfX <- dfX %>% dplyr::mutate(bid = bid+max(pid))
dfX <- dfX %>% dplyr::mutate(sid = sid+max(bid))

Expand All @@ -64,8 +64,8 @@ mnre_simulate_ev_data <- function(nlim=1000, year=2016, OBP=FALSE) {
k_class <- max(dfX$y)
beta_re <- matrix(rep(0, k_class * dim(re)[[2]]), ncol=k_class)
beta_fe <- matrix(rep(0, k_class * dim(fe)[[2]]), ncol=k_class)
xx <- model.matrix(y ~ BAT_ID + PIT_ID + HOME_TEAM_ID, data=dfX)
# xx <- model.matrix(y ~ BAT_ID + PIT_ID, data=dfX)
xx <- model.matrix(y ~ bat_id + pit_id + home_team_id, data=dfX)
# xx <- model.matrix(y ~ bat_id + pit_id, data=dfX)
y <- matrix(dfX$y, ncol=1)
theta_init <- matrix(rep(glf$reTrms$theta, k_class), ncol=k_class)
list(fr=dfX, frm=glf$formula,
Expand Down Expand Up @@ -256,4 +256,63 @@ nd_min_fun <- function(ev) {
}
}

#' @importFrom magrittr %>%
#' @importFrom magrittr %$%
#' @importFrom magrittr %<>%
#'
#' @export
mnre_example_retrosheet_event_data <- function(obp=FALSE) {
ev <- readRDS(system.file("extdata/events2017.rds", package = "mnre"))

# rm pitchers as hitters
ev %<>% filter(bat_fld_cd != 1)

# anyone with less than 20 PA hitting is generic
lowpa_batters <- ev %>%
dplyr::group_by(bat_id) %>%
dplyr::summarise(PA=n()) %>%
dplyr::filter(PA<=20) %$% bat_id

# anyone with less than 20 PA hitting is generic
lowpa_pitchers <- ev %>%
group_by(pit_id) %>%
summarise(PA=n()) %>%
filter(PA<=20) %$% pit_id

if (length(lowpa_batters) > 0) {
cc <- which(ev$bat_id %in% lowpa_batters)
ev[cc,]$bat_id <- "xxxxb001"
}

if (length(lowpa_pitchers) > 0) {
cc <- which(ev$pit_id %in% lowpa_pitchers)
ev[cc,]$pit_id <- "xxxxp001"
}

cc_hr <- which(ev$event_cd == 23)
cc_so <- which(ev$event_cd == 3)
cc_bip0 <- which(ev$event_cd == 2)
cc_bip1 <- which(ev$event_cd == 20)
cc_bip2 <- which(ev$event_cd >= 21 & ev$event_cd <= 22)
cc_bb <- which(ev$event_cd >= 14 & ev$event_cd <= 16)

ev$outcome <- NA

if (obp) {
ev[c(cc_bip0, cc_so),]$outcome <- 0
ev[c(cc_bip1, cc_bip2, cc_hr, cc_bb),]$outcome <- 1
} else {
ev[cc_bip0,]$outcome <- 0
ev[cc_bip1,]$outcome <- 1
ev[cc_bip2,]$outcome <- 2
ev[cc_hr,]$outcome <- 3
ev[cc_so,]$outcome <- 4
ev[cc_bb,]$outcome <- 5
}

ev %<>% select(game_id, event_id, event_cd, bat_id, pit_id, home_team_id, outcome)

ev
}


4 changes: 2 additions & 2 deletions R/mnre_fit.R
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@ mnre_fit <- function(frm, data, verbose=0, off_diagonal=0.0) {
ev$verbose <- verbose

nlev <- length(all.vars(ev$frm))
mval <- rep(1, (nlev-1) * max(ev$fr$y))
mval <- rep(1, (nlev-1) * max(ev$fr[[all.vars(frm)[1]]]))

nf <- nd_min_fun(ev)

Expand Down Expand Up @@ -54,7 +54,7 @@ mnre_fit_to_df <- function(frm, data, mval, verbose=0, off_diagonal=0.0) {
df_names <- c(df_names, "ranef_level")

cc1$ranef <- ranef_labels[cc1[,ncol(cc1)]]
cc1$lv <- matrix(lvs, ncol=1)
cc1$lv <- as.vector(matrix(lvs, ncol=1))

mvalX <- t(sapply(1:max(Lind), function(i) {
idx = which(cc1[,k_class+1] == i)
Expand Down
Binary file added inst/extdata/events2017.rds
Binary file not shown.

0 comments on commit 6819276

Please sign in to comment.