Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/nflverse/nfl4th

NFL 4th down decision calculator
https://github.com/nflverse/nfl4th

cran nfl nfl-analytics nflfastr

Last synced: about 2 months ago
JSON representation

NFL 4th down decision calculator

Awesome Lists containing this project

README

        

---
output: github_document
---

```{r, include = FALSE}
knitr::opts_chunk$set(
collapse = TRUE,
comment = "#>",
fig.path = "man/figures/README-",
out.width = "100%"
)
```

# **nfl4th**

[![R-CMD-check](https://github.com/nflverse/nfl4th/workflows/R-CMD-check/badge.svg)](https://github.com/nflverse/nfl4th/actions)
[![CRAN status](https://www.r-pkg.org/badges/version-last-release/nfl4th)](https://CRAN.R-project.org/package=nfl4th)
[![Lifecycle: stable](https://img.shields.io/badge/lifecycle-stable-brightgreen.svg)](https://lifecycle.r-lib.org/articles/stages.html#stable)
[![Support Server](https://img.shields.io/discord/789805604076126219.svg?color=7289da&label=Support&logo=discord&style=flat-square)](https://discord.com/invite/5Er2FBnnQa)

This is the package that powers the [fourth down calculator](https://rbsdm.com/stats/fourth_calculator/) introduced in [this piece on The Athletic](https://theathletic.com/2144214/2020/10/28/nfl-fourth-down-decisions-the-math-behind-the-leagues-new-aggressiveness/).

The code that powers the Twitter fourth down bot [is in this folder here](https://github.com/guga31bb/fourth_calculator/tree/main/bot) and the [code that runs the Shiny app is here](https://github.com/guga31bb/fourth_calculator/blob/main/app.R).

## Installation

The easiest way to get the released version of nfl4th is to install it from [CRAN](https://cran.r-project.org/package=nfl4th) with:

``` r
install.packages("nfl4th")
```

To get a bug fix or to use a feature from the development version, you can install the development version of nfl4th from [GitHub](https://github.com/nflverse/nfl4th/) with:

```r
install.packages("nfl4th", repos = c("https://nflverse.r-universe.dev", getOption("repos")))
```

or by using remotes:

``` r
if (!require("remotes")) install.packages("remotes")
remotes::install_github("nflverse/nfl4th")
```

## Features

* The **go for it** model gives probabilities for possibilities of yards gained and includes the possibility of earning a first down via defensive penalty
* The **punt** model includes the possibility for getting blocked, returned for a touchdown, or fumbled on the return
* The **field goal** model is a simple model of field goal % by distance and roof type

## Current limitations

There are some edge cases that are not accounted for. These should only make a marginal difference to the recommendations as they are largely edge cases (e.g. the possibility for a field goal to be blocked and returned).

* The **go for it** model does not allow for the possibility of a turnover return. However, long returns are extremely rare: For example, in 2018 and 2019 there were only four defensive touchdowns on plays where teams went for fourth downs out of 1,236 plays, and all of these happened when the game was well in hand for the other team.
* The **punt** model doesn’t account for the punter or returner, ignores penalties on returns and ignores the potential for blocked punts to be returned for touchdowns
* The **field goal** model doesn’t account for who the kicker is, what the weather is (only relevant for outdoor games), or the possibility of a kick being blocked and returned for a touchdown

## Get Started

To get started with nfl4th please see [this article](https://www.nfl4th.com/articles/articles/nfl4th.html). Some examples of 4th down research using the package [can be found here](https://www.nfl4th.com/articles/articles/4th-down-research.html).