This function detects outliers using the maximum normed residual method described in CMH-17-1G. This method identifies a value as an outlier if the absolute difference between the value and the sample mean divided by the sample standard deviation exceeds a critical value.
maximum_normed_residual(data = NULL, x, alpha = 0.05)an object of class mnr
This object has the following fields:
call the expression used to call this function
data the original data used to compute the MNR
alpha the value of alpha given by the user
mnr the computed MNR test statistic
crit the critical value given the sample size and the
significance level
outliers a data.frame containing the index and
value of each of the identified outliers
n_outliers the number of outliers found
data is an optional argument. If data is given, it
should be a
data.frame (or similar object). When data is specified, the
value of x is expected to be a variable within data. If
data is not specified, x must be a vector.
The maximum normed residual test is a test for outliers. The test statistic is given in CMH-17-1G. Outliers are identified in the returned object.
The maximum normed residual test statistic is defined as:
$$MNR = max \frac{\left| x_i - \bar{x} \right|}{s} $$
When the value of the MNR test statistic exceeds the critical value defined in Section 8.3.3.1 of CMH-17-1G, the corresponding value is identified as an outlier. It is then removed from the sample, and the test statistic is computed again and compared with the critical value corresponding with the new sample. This process is repeated until no values are identified as outliers.
“Composite Materials Handbook, Volume 1. Polymer Matrix Composites Guideline for Characterization of Structural Materials,” SAE International, CMH-17-1G, Mar. 2012.
library(dplyr)
carbon.fabric.2 %>%
filter(test=="FC" & condition=="ETW2" & batch=="A") %>%
maximum_normed_residual(strength)
#>
#> Call:
#> maximum_normed_residual(data = ., x = strength)
#>
#> MNR = 1.958797 ( critical value = 1.887145 )
#>
#> Outliers ( alpha = 0.05 ):
#> Index Value
#> 6 44.26
## Call:
## maximum_normed_residual(data = ., x = strength)
##
## MNR = 1.958797 ( critical value = 1.887145 )
##
## Outliers ( alpha = 0.05 ):
## Index Value
## 6 44.26
carbon.fabric.2 %>%
filter(test=="FC" & condition=="ETW2" & batch=="B") %>%
maximum_normed_residual(strength)
#>
#> Call:
#> maximum_normed_residual(data = ., x = strength)
#>
#> MNR = 1.469517 ( critical value = 1.887145 )
#>
#> No outliers detected ( alpha = 0.05 )
#>
## Call:
## maximum_normed_residual(data = ., x = strength)
##
## MNR = 1.469517 ( critical value = 1.887145 )
##
## No outliers detected ( alpha = 0.05 )