Summary statistics for a single numeric variable, possibly separated by the levels of a factor variable or variables. This function is very similar to summary for a numeric variable.
Usage
Summarize(object, ...)
# Default S3 method
Summarize(
  object,
  digits = getOption("digits"),
  na.rm = TRUE,
  exclude = NULL,
  nvalid = c("different", "always", "never"),
  percZero = c("different", "always", "never"),
  ...
)
# S3 method for class 'formula'
Summarize(
  object,
  data = NULL,
  digits = getOption("digits"),
  na.rm = TRUE,
  exclude = NULL,
  nvalid = c("different", "always", "never"),
  percZero = c("different", "always", "never"),
  ...
)Arguments
- object
- A vector of numeric data. 
- ...
- Not implemented. 
- digits
- A single numeric that indicates the number of decimals to round the numeric summaries. 
- na.rm
- A logical that indicates whether numeric missing values ( - NA) should be removed (- =TRUE, default) or not.
- exclude
- A string that contains the level that should be excluded from a factor variable. 
- nvalid
- A string that indicates how the “validn” result will be handled. If - "always"then “validn” will always be shown and if- "never"then “validn” will never be shown. However, if- "different"(DEFAULT), then “validn” will only be shown if it differs from “n” (or if at least one group differs from “n” when summarized by multiple groups).
- percZero
- A string that indicates how the “percZero” result will be handled. If - "always"then “percZero” will always be shown and if- "never"then “percZero” will never be shown. However, if- "different"(DEFAULT), then “percZero” will only be shown if it is greater than zero (or if at least one group is greater than zero when summarized by multiple groups).
- data
- A data.frame that contains the variables in - formula.
Value
A named vector or data frame (when a quantitative variable is separated by one or two factor variables) of summary statistics for numeric data.
Details
This function is primarily used with formulas of the following types (where quant and factor generically represent quantitative/numeric and factor variables, respectively):
| Formula | Description of Summary | 
| ~quant | Numerical summaries (see below) of quant. | 
| quant~factor | Summaries of quantseparated by levels infactor. | 
| quant~factor1*factor2 | Summaries of quantseparated by the combined levels infactor1andfactor2. | 
Numerical summaries include all results from summary (min, Q1, mean, median, Q3, and max) and the sample size, valid sample size (sample size minus number of NAs), and standard deviation (i.e., sd). NA values are removed from the calculations with na.rm=TRUE (the DEFAULT). The number of digits in the returned results are controlled with digits=.
Note
Students often need to examine basic statistics of a quantitative variable separated for different levels of a categorical variable. These results may be obtained with tapply, by, or aggregate (or with functions in other packages), but the use of these functions is not obvious to newbie students or return results in a format that is not obvious to newbie students. Thus, the formula method to Summarize allows newbie students to use a common notation (i.e., formula) to easily compute summary statistics for a quantitative variable separated by the levels of a factor.
Author
Derek H. Ogle, DerekOgle51@gmail.com
Examples
## Create a data.frame of "data"
n <- 102
d <- data.frame(y=c(0,0,NA,NA,NA,runif(n-5)),
                w=sample(7:9,n,replace=TRUE),
                v=sample(0:2,n,replace=TRUE),
                g1=factor(sample(c("A","B","C",NA),n,replace=TRUE)),
                g2=factor(sample(c("male","female","UNKNOWN"),n,replace=TRUE)),
                g3=sample(c("a","b","c","d"),n,replace=TRUE),
                stringsAsFactors=FALSE)
# typical output of summary() for a numeric variable
summary(d$y)   
#>    Min. 1st Qu.  Median    Mean 3rd Qu.    Max.    NA's 
#>  0.0000  0.1828  0.4444  0.4628  0.7224  0.9870       3 
# this function           
Summarize(d$y,digits=3)
#>        n   nvalid     mean       sd      min       Q1   median       Q3 
#>  102.000   99.000    0.463    0.303    0.000    0.183    0.444    0.722 
#>      max percZero 
#>    0.987    2.020 
Summarize(~y,data=d,digits=3)
#>        n   nvalid     mean       sd      min       Q1   median       Q3 
#>  102.000   99.000    0.463    0.303    0.000    0.183    0.444    0.722 
#>      max percZero 
#>    0.987    2.020 
Summarize(y~1,data=d,digits=3)
#>        n   nvalid     mean       sd      min       Q1   median       Q3 
#>  102.000   99.000    0.463    0.303    0.000    0.183    0.444    0.722 
#>      max percZero 
#>    0.987    2.020 
# note that nvalid is not shown if there are no NAs and
#   percZero is not shown if there are no zeros
Summarize(~w,data=d,digits=3)
#>       n    mean      sd     min      Q1  median      Q3     max 
#> 102.000   8.000   0.833   7.000   7.000   8.000   9.000   9.000 
Summarize(~v,data=d,digits=3)
#>        n     mean       sd      min       Q1   median       Q3      max 
#>  102.000    1.049    0.849    0.000    0.000    1.000    2.000    2.000 
#> percZero 
#>   33.333 
# note that the nvalid and percZero results can be forced to be shown
Summarize(~w,data=d,digits=3,nvalid="always",percZero="always")
#>        n   nvalid     mean       sd      min       Q1   median       Q3 
#>  102.000  102.000    8.000    0.833    7.000    7.000    8.000    9.000 
#>      max percZero 
#>    9.000    0.000 
## Numeric vector by levels of a factor variable
Summarize(y~g1,data=d,digits=3)
#>   g1  n nvalid  mean    sd   min    Q1 median    Q3   max percZero
#> 1  A 34     33 0.470 0.294 0.009 0.213  0.444 0.733 0.974        0
#> 2  B 25     25 0.521 0.308 0.000 0.264  0.485 0.866 0.970        4
#> 3  C 23     23 0.424 0.275 0.015 0.180  0.466 0.656 0.959        0
Summarize(y~g2,data=d,digits=3)
#>        g2  n nvalid  mean    sd   min    Q1 median    Q3   max percZero
#> 1 UNKNOWN 34     31 0.408 0.316 0.011 0.140  0.391 0.646 0.987    0.000
#> 2  female 48     48 0.504 0.291 0.000 0.258  0.510 0.760 0.959    2.083
#> 3    male 20     20 0.449 0.312 0.000 0.165  0.400 0.710 0.970    5.000
Summarize(y~g2,data=d,digits=3,exclude="UNKNOWN")
#>       g2  n  mean    sd min    Q1 median   Q3   max percZero
#> 1 female 48 0.504 0.291   0 0.258   0.51 0.76 0.959    2.083
#> 2   male 20 0.449 0.312   0 0.165   0.40 0.71 0.970    5.000
## Numeric vector by levels of two factor variables
Summarize(y~g1+g2,data=d,digits=3)
#>   g1      g2  n nvalid  mean    sd   min    Q1 median    Q3   max percZero
#> 1  A UNKNOWN 11     10 0.442 0.319 0.011 0.237  0.418 0.496 0.974    0.000
#> 2  B UNKNOWN  5      5 0.561 0.307 0.242 0.391  0.392 0.868 0.913    0.000
#> 3  C UNKNOWN  9      9 0.347 0.270 0.043 0.072  0.296 0.601 0.716    0.000
#> 4  A  female 17     17 0.491 0.296 0.009 0.331  0.494 0.761 0.918    0.000
#> 5  B  female 13     13 0.543 0.268 0.123 0.285  0.510 0.781 0.927    0.000
#> 6  C  female 12     12 0.487 0.291 0.015 0.187  0.591 0.667 0.959    0.000
#> 7  A    male  6      6 0.454 0.294 0.076 0.209  0.529 0.670 0.774    0.000
#> 8  B    male  7      7 0.454 0.407 0.000 0.101  0.393 0.805 0.970   14.286
#> 9  C    male  2      2 0.389 0.219 0.234 0.311  0.389 0.466 0.543    0.000
Summarize(y~g1+g2,data=d,digits=3,exclude="UNKNOWN")
#>   g1     g2  n  mean    sd   min    Q1 median    Q3   max percZero
#> 1  A female 17 0.491 0.296 0.009 0.331  0.494 0.761 0.918    0.000
#> 2  B female 13 0.543 0.268 0.123 0.285  0.510 0.781 0.927    0.000
#> 3  C female 12 0.487 0.291 0.015 0.187  0.591 0.667 0.959    0.000
#> 4  A   male  6 0.454 0.294 0.076 0.209  0.529 0.670 0.774    0.000
#> 5  B   male  7 0.454 0.407 0.000 0.101  0.393 0.805 0.970   14.286
#> 6  C   male  2 0.389 0.219 0.234 0.311  0.389 0.466 0.543    0.000
## What happens if RHS of formula is not a factor
Summarize(y~w,data=d,digits=3)
#>   w  n nvalid  mean    sd   min    Q1 median    Q3   max percZero
#> 1 7 35     35 0.527 0.335 0.015 0.198  0.651 0.825 0.974    0.000
#> 2 8 32     30 0.469 0.282 0.009 0.300  0.418 0.701 0.987    0.000
#> 3 9 35     34 0.391 0.279 0.000 0.152  0.399 0.562 0.964    5.882
## Summarizing multiple variables in a data.frame (must reduce to numerics)
lapply(as.list(d[,1:3]),Summarize,digits=4)
#> $y
#>        n   nvalid     mean       sd      min       Q1   median       Q3 
#> 102.0000  99.0000   0.4628   0.3034   0.0000   0.1828   0.4444   0.7224 
#>      max percZero 
#>   0.9870   2.0202 
#> 
#> $w
#>        n     mean       sd      min       Q1   median       Q3      max 
#> 102.0000   8.0000   0.8325   7.0000   7.0000   8.0000   9.0000   9.0000 
#> 
#> $v
#>        n     mean       sd      min       Q1   median       Q3      max 
#> 102.0000   1.0490   0.8487   0.0000   0.0000   1.0000   2.0000   2.0000 
#> percZero 
#>  33.3333 
#> 
