Current issue

Vol.26 No.4

Vol.26 No.4

Volumes

© 1984-2024
British APL Association
All rights reserved.

Archive articles posted online on request: ask the archivist.

archive/26/1

Volume 26, No.1

NFL Passer Rating

Brian Becker

I like football, both the American version and the version the rest of the world calls football but the Americans call “soccer”. One of the statistics in American football that’s frequently mentioned is the passer (or quarterback) rating. I've heard sportscasters say the maximum passer rating is 158.3 – a rather odd number if you ask me. This piqued my curiosity and I turned to the font of all knowledge – the internet, where I found an interesting entry in en.wikipedia.org[1] which gave the following formula:

a = COMP ATT - 0.3 × 5

b = YARDS ATT - 3 × .25

c = TD ATT × 20

d = 2.375 - INT ATT × 25

Where:

ATT = Number of passing attempts
COMP = Number of completions
YARDS = Passing yards
YARDS = Touchdown passes
INT = Interceptions

Then, the above calculations are used to complete the passer rating:

PasserRating NFL = mm a + mm b + mm c + mm d 6 × 100

Where: mm x = max 0 min x 2.375

I thought it might be interesting to model the formula in APL and look at the impact of the various inputs, for instance what happens if a passer completes only 50% of his passes, but every pass he completes is for a touchdown?

It’s fairly straightforward to translate the formula directly into APL:

     ∇ rating←att PasserRating(comp yards td int);a;b;c;d;mm
[1]    mm←{0⌈2.375⌊⍵}          ⍝ define the max/min function
[2]    a←((comp÷att)-0.3)×5
[3]    b←((yards÷att)-3)×0.25
[4]    c←(td÷att)×20
[5]    d←2.375-(int÷att)×25
[6]    rating←(((mm a)+(mm b)+(mm c)+(mm d))÷6)×100
     ∇

For instance, a quarterback who completes 17 of 20 attempts for 300 yards, 4 touchdowns, and no interceptions would have a “perfect” rating of 158.3.

      20 PasserRating 17 300 4 0
158.3333333

The above function works just fine, but it’s not particularly “APL-like”. By this I mean that it’s longer than it needs to be and doesn't really make use of APL's array handling capabilities.

One of the first things I noticed was that all of the terms (completions, yards, TDs and interceptions) are treated similarly…

  • they’re each divided by the number of attempts
  • the result of that operation is adjusted by some number (in some cases the number is 0)
  • those results are then multiplied by some number
  • then those results are added (or subtracted) from a number (again that number may be 0)
  • the mm function is applied to each result

Then to complete the calculation the results are summed, that sum is divided by 6 and then multiplied by 100.

So, if instead of having 4 terms (comp, yards, tds, and int) we have one term “stats” which is a 4 element vector comprised of comp, yards, tds, and int, we can simplify the first operation to:

      stats÷att

The next step is to adjust each result by some number, -0.3 for completions, -3 for yards, and 0 for each of TDs and interceptions. There are a few ways to do this in APL…

      (stats ÷ att) - .3 3 0 0 ⍝ is the most straightforward
      ¯.3 ¯3 0 0 + stats ÷ att ⍝ removes the parentheses
      .3 3 0 0 -⍨ stats ÷ att  ⍝ uses subtraction and the commute operator ⍨
                               ⍝ which commutes (switches) the arguments

All of these statements produce equivalent results. So, you can use whichever seems most straightforward to you.

Each of these results is multiplied by a number: 5 for completions, .25 for yards, 20 for TDs, and -25 for interceptions. Why use -25? Because the interception result is subtracted from 2.375 in the subsequent operation.

      0 0 0 2.375 + 5 .25 20 ¯25 × .3 3 0 0 -⍨ stats ÷ att

Next the mm (max/min) function gets applied; it’s so trivial we can skip writing a separate function…

      0 ⌈ 2.375 ⌊ 0 0 0 2.375 + 5 .25 20 ¯25 × .3 3 0 0 -⍨ stats ÷ att

Then those results are summed…

      +/ 0 ⌈ 2.375 ⌊ 0 0 0 2.375 + 5 .25 20 ¯25 × .3 3 0 0 -⍨ stats ÷ att

The sum is the divided by 6 and multiplied by 100, again there are several ways to accomplish this…

      100 × (+/ 0 ⌈ 2.375 ⌊ 0 0 0 2.375 + 5 .25 20 ¯25 × .3 3 0 0 -⍨ stats ÷ att) ÷ 6
      (100 ÷ 6) × +/ 0 ⌈ 2.375 ⌊ 0 0 0 2.375 + 5 .25 20 ¯25 × .3 3 0 0 -⍨ stats ÷ att
      100 × 6 ÷⍨ +/ 0 ⌈ 2.375 ⌊ 0 0 0 2.375 + 5 .25 20 ¯25 × .3 3 0 0 -⍨ stats ÷ att

Putting it all together, we can rewrite our function as:

     ∇ rating←att PasserRating stats
 [1]    rating←100×6÷⍨+/0⌈2.375⌊0 0 0 2.375+5 .25 20 ¯25×.3 3 0 0-⍨stats÷att
     ∇

This is known as a trad-fn (traditional function) in Dyalog APL. Dyalog also has d-fns (dynamic functions). PasserRating written as a d-fn would look like:

      PasserRating←{100×6÷⍨+/0⌈2.375⌊0 0 0 2.375+5 0.25 20 ¯25×.3 3 0 0-⍨⍵÷⍺}

Once you have the PasserRating function, you can see the effect of the different inputs. For instance, what if the passer had the same results (17 completions, 300 yards, 4 TDs, and 0 interceptions) but the number of attempts varied?

      {'Attempts' 'Rating'⍪⍵,[1.1](PasserRating∘17 300 4 0)¨⍵}16+⍳16
 Attempts       Rating
       17  158.3333333
       18  158.3333333
       19  158.3333333
       20  158.3333333
       21  158.3333333
       22  158.1439394
       23  155.3442029
       24  152.7777778
       25  148.3333333
       26  144.2307692
       27  140.4320988
       28  136.9047619
       29  133.6206897
       30  130.5555556
       31  127.688172
       32  125

Does the passer rating formula make sense? For instance, consider two quarterbacks who each have 20 attempts and pass for 400 yards. The first quarterback has only 10 completions, but each of those is for a touchdown. The second quarterback has 20 completions, but only 1 touchdown. Who’s the higher rated quarterback? According to the formula, they both have the same rating.

      20 PasserRating ¨(10 400 10 0)(20 400 1 0)
135.4166667 135.4166667

Perhaps “passer“ rating is less interesting than a “quarterback” rating which, in addition, could take into account things like:

  • sacks – a quarterback who less aware of his surroundings and is sacked more frequently isn’t as effective
  • fumbles – similarly a quarterback who fumbles more often isn’t as effective
  • yards gained – most of today’s quarterbacks have to be somewhat mobile

Can passer rating be improved upon? There are lots of possibilities and APL makes it easy, even fun, to explore them.

References

  1. Passer rating http://en.wikipedia.org/wiki/Passer_rating

 

script began 20:54:47
caching off
debug mode off
cache time 3600 sec
indmtime not found in cache
cached index is fresh
recompiling index.xml
index compiled in 0.2236 secs
read index
read issues/index.xml
identified 26 volumes, 101 issues
array (
  'id' => '10501200',
)
regenerated static HTML
article source is 'XHTML'
completed in 0.2465 secs