Package 'mmcm'

Title: Modified Maximum Contrast Method
Description: An implementation of modified maximum contrast methods (Sato et al. (2009) <doi:10.1038/tpj.2008.17>; Nagashima et al. (2011) <doi:10.2202/1544-6115.1560>) and the maximum contrast method (Yoshimura et al. (1997) <doi:10.1177/009286159703100213>): Functions mmcm.mvt() and mcm.mvt() give P-value by using randomized quasi-Monte Carlo method with pmvt() function of package 'mvtnorm', and mmcm.resamp() gives P-value by using a permutation method.
Authors: Kengo Nagashima [aut, cre] , Yasunori Sato [aut]
Maintainer: Kengo Nagashima <[email protected]>
License: GPL-3
Version: 1.2-8
Built: 2024-12-26 06:30:20 UTC
Source: CRAN

Help Index


The modified maximum contrast method package

Description

This package provides an implementation of modified maximum contrast methods and the maximum contrast method. This version supports functions mmcm.mvt, mcm.mvt that gives P-value by using randomized quasi-Monte Carlo method from pmvt function of package mvtnorm, and mmcm.resamp that gives P-value by using the permutation method. In a one-way problem testing pattern of several factor level means, the maximum contrast statistics (Yoshimura, I., 1997) may be used. But under unequal sample size situations, denominator of the maximum contrast statistics is overestimated. Thus we propose a modified maximum contrast statistics for the unequal sample size situation. Denominetor of the modified maximum contrast statistics is not influenced under the unequal sample size situation.

References

Nagashima, K., Sato, Y., Hamada, C. (2011). A modified maximum contrast method for unequal sample sizes in pharmacogenomic studies Stat Appl Genet Mol Biol. 10(1): Article 41. http://dx.doi.org/10.2202/1544-6115.1560

Sato, Y., Laird, N.M., Nagashima, K., et al. (2009). A new statistical screening approach for finding pharmacokinetics-related genes in genome-wide studies. Pharmacogenomics J. 9(2): 137–146. http://www.ncbi.nlm.nih.gov/pubmed/19104505

Yoshimura, I., Wakana, A., Hamada, C. (1997). A performance comparison of maximum contrast methods to detect dose dependency. Drug Information J. 31: 423–432.

See Also

mcm.mvt, mmcm.mvt, mmcm.resamp


The maximum contrast method by using the randomized quasi-Monte Carlo method

Description

This function gives PP-value for the maximum contrast statistics by using randomized quasi-Monte Carlo method from pmvt function of package mvtnorm.

Usage

mcm.mvt(
  x,
  g,
  contrast,
  alternative = c("two.sided", "less", "greater"),
  algorithm = GenzBretz()
)

Arguments

x

a numeric vector of data values

g

a integer vector giving the group for the corresponding elements of x

contrast

a numeric contrast coefficient matrix for the maximum contrast statistics

alternative

a character string specifying the alternative hypothesis, must be one of "two.sided" (default), "greater" or "less". You can specify just the initial letter.

algorithm

an object of class GenzBretz defining the hyper parameters of this algorithm

Details

mcm.mvt performs the maximum contrast method that is detecting a true response pattern.

Yij(i=1,2,;j=1,2,,ni)Y_{ij} (i=1, 2, \ldots; j=1, 2, \ldots, n_i) is an observed response for jj-th individual in ii-th group.

C\bm{C} is coefficient matrix for the maximum contrast statistics (i×ki \times k matrix, ii: No. of groups, kk: No. of pattern).

C=(c1,c2,,ck)T\bm{C}=(\bm{c}_1, \bm{c}_2, \ldots, \bm{c}_k)^{\rm{T}}

ck\bm{c}_k is coefficient vector of kkth pattern.

ck=(ck1,ck2,,cki)T(icki=0)\bm{c}_k=(c_{k1}, c_{k2}, \ldots, c_{ki})^{\rm{T}} \qquad (\textstyle \sum_i c_{ki}=0)

TmaxT_{\max} is the maximum contrast statistic.

Yˉi=j=1niYijni,Yˉ=(Yˉ1,Yˉ2,,Yˉi,,Yˉa)T,\bar{Y}_i=\frac{\sum_{j=1}^{n_i} Y_{ij}}{n_{i}}, \bar{\bm{Y}}=(\bar{Y}_1, \bar{Y}_2, \ldots, \bar{Y}_i, \ldots, \bar{Y}_a)^{\rm{T}},

D=diag(n1,n2,,ni,,na),V=1γj=1nii=1a(YijYˉi)2,\bm{D}=diag(n_1, n_2, \ldots, n_i, \ldots, n_a), V=\frac{1}{\gamma}\sum_{j=1}^{n_i}\sum_{i=1}^{a} (Y_{ij}-\bar{Y}_i)^2,

γ=i=1a(ni1),Tk=cktYˉVcktDck,\gamma=\sum_{i=1}^{a} (n_i-1), T_{k}=\frac{\bm{c}^t_k \bar{\bm{Y}}}{\sqrt{V\bm{c}^t_k \bm{D} \bm{c}_k}},

Tmax=max(T1,T2,,Tk).T_{\max}=\max(T_1, T_2, \ldots, T_k).

Consider testing the overall null hypothesis H0:μ1=μ2==μiH_0: \mu_1=\mu_2=\ldots=\mu_i, versus alternative hypotheses H1H_1 for response petterns (H1:μ1<μ2<<μi, μ1=μ2<<μi, μ1<μ2<=μiH_1: \mu_1<\mu_2<\ldots<\mu_i,~ \mu_1=\mu_2<\ldots<\mu_i,~ \mu_1<\mu_2<\ldots=\mu_i). The PP-value for the probability distribution of TmaxT_{\max} under the overall null hypothesis is

P-value=Pr(Tmax>tmaxH0)P\mbox{-value}=\Pr(T_{\max}>t_{\max} \mid H_0)

tmaxt_{\max} is observed value of statistics. This function gives distribution of TmaxT_{\max} by using randomized quasi-Monte Carlo method from package mvtnorm.

Value

statistic

the value of the test statistic with a name describing it.

p.value

the p-value for the test.

alternative

a character string describing the alternative hypothesis.

method

the type of test applied.

contrast

a character string giving the names of the data.

contrast.index

a suffix of coefficient vector of the kkth pattern that gives maximum contrast statistics (row number of the coefficient matrix).

error

estimated absolute error and,

msg

status messages.

References

Yoshimura, I., Wakana, A., Hamada, C. (1997). A performance comparison of maximum contrast methods to detect dose dependency. Drug Information J. 31: 423–432.

See Also

pmvt, GenzBretz, mmcm.mvt

Examples

## Example 1 ##
#  true response pattern: dominant model c=(1, 1, -2)
set.seed(136885)
x <- c(
  rnorm(130, mean =  1 / 6, sd = 1),
  rnorm( 90, mean =  1 / 6, sd = 1),
  rnorm( 10, mean = -2 / 6, sd = 1)
)
g <- rep(1:3, c(130, 90, 10))
boxplot(
  x ~ g,
  width = c(length(g[g==1]), length(g[g==2]), length(g[g==3])),
  main = "Dominant model (sample data)",
  xlab = "Genotype",
  ylab = "PK parameter"
)

# coefficient matrix
# c_1: additive, c_2: recessive, c_3: dominant
contrast <- rbind(
  c(-1, 0, 1), c(-2, 1, 1), c(-1, -1, 2)
)
y <- mcm.mvt(x, g, contrast)
y

## Example 2 ##
#  for dataframe
#  true response pattern:
#    pos = 1 dominant  model c=( 1,  1, -2)
#          2 additive  model c=(-1,  0,  1)
#          3 recessive model c=( 2, -1, -1)
set.seed(3872435)
x <- c(
  rnorm(130, mean =  1 / 6, sd = 1),
  rnorm( 90, mean =  1 / 6, sd = 1),
  rnorm( 10, mean = -2 / 6, sd = 1),
  rnorm(130, mean = -1 / 4, sd = 1),
  rnorm( 90, mean =  0 / 4, sd = 1),
  rnorm( 10, mean =  1 / 4, sd = 1),
  rnorm(130, mean =  2 / 6, sd = 1),
  rnorm( 90, mean = -1 / 6, sd = 1),
  rnorm( 10, mean = -1 / 6, sd = 1)
)
g   <- rep(rep(1:3, c(130, 90, 10)), 3)
pos <- rep(c("rsXXXX", "rsYYYY", "rsZZZZ"), each=230)
xx  <- data.frame(pos = pos, x = x, g = g)

# coefficient matrix
# c_1: additive, c_2: recessive, c_3: dominant
contrast <- rbind(
  c(-1, 0, 1), c(-2, 1, 1), c(-1, -1, 2)
)
y <- by(xx, xx$pos, function(x) mmcm.mvt(x$x, x$g,
  contrast))
y <- do.call(rbind, y)[,c(3,7,9)]
# miss-detection!
y

The modified maximum contrast method by using randomized quasi-Monte Carlo method

Description

This function gives PP-value for the modified maximum contrast statistics by using randomized quasi-Monte Carlo method from pmvt function of package mvtnorm.

Usage

mmcm.mvt(
  x,
  g,
  contrast,
  alternative = c("two.sided", "less", "greater"),
  algorithm = GenzBretz()
)

Arguments

x

a numeric vector of data values

g

a integer vector giving the group for the corresponding elements of x

contrast

a numeric contrast coefficient matrix for modified maximum contrast statistics

alternative

a character string specifying the alternative hypothesis, must be one of "two.sided" (default), "greater" or "less". You can specify just the initial letter.

algorithm

an object of class GenzBretz defining the hyper parameters of this algorithm.

Details

mmcm.mvt performs the modified maximum contrast method that is detecting a true response pattern under the unequal sample size situation.

Yij(i=1,2,;j=1,2,,ni)Y_{ij} (i=1, 2, \ldots; j=1, 2, \ldots, n_i) is an observed response for jj-th individual in ii-th group.

C\bm{C} is coefficient matrix for modified maximum contrast statistics (i×ki \times k matrix, ii: No. of groups, kk: No. of pattern).

C=(c1,c2,,ck)T\bm{C}=(\bm{c}_1, \bm{c}_2, \ldots, \bm{c}_k)^{\rm{T}}

ck\bm{c}_k is coefficient vector of kkth pattern.

ck=(ck1,ck2,,cki)T(icki=0)\bm{c}_k=(c_{k1}, c_{k2}, \ldots, c_{ki})^{\rm{T}} \qquad (\textstyle \sum_i c_{ki}=0)

SmaxS_{\max} is the modified maximum contrast statistic.

Yˉi=j=1niYijni,Yˉ=(Yˉ1,Yˉ2,,Yˉi,,Yˉa)T,\bar{Y}_i=\frac{\sum_{j=1}^{n_i} Y_{ij}}{n_{i}}, \bar{\bm{Y}}=(\bar{Y}_1, \bar{Y}_2, \ldots, \bar{Y}_i, \ldots, \bar{Y}_a)^{\rm{T}},

V=1γj=1nii=1a(YijYˉi)2,γ=i=1a(ni1),V=\frac{1}{\gamma}\sum_{j=1}^{n_i}\sum_{i=1}^{a} (Y_{ij}-\bar{Y}_i)^2, \gamma=\sum_{i=1}^{a} (n_i-1),

Sk=cktYˉVcktck,S_{k}=\frac{\bm{c}^t_k \bar{\bm{Y}}}{\sqrt{V \bm{c}^t_k \bm{c}_k}},

Smax=max(S1,S2,,Sk).S_{\max}=\max(S_1, S_2, \ldots, S_k).

Consider testing the overall null hypothesis H0:μ1=μ2==μiH_0: \mu_1=\mu_2=\ldots=\mu_i, versus alternative hypotheses H1H_1 for response petterns (H1:μ1<μ2<<μi, μ1=μ2<<μi, μ1<μ2<=μiH_1: \mu_1<\mu_2<\ldots<\mu_i,~ \mu_1=\mu_2<\ldots<\mu_i,~ \mu_1<\mu_2<\ldots=\mu_i). The PP-value for the probability distribution of SmaxS_{\max} under the overall null hypothesis is

P-value=Pr(Smax>smaxH0)P\mbox{-value}=\Pr(S_{\max}>s_{\max} \mid H_0)

smaxs_{\max} is observed value of statistics. This function gives distribution of SmaxS_{\max} by using randomized quasi-Monte Carlo method from package mvtnorm.

Value

statistic

the value of the test statistic with a name describing it.

p.value

the p-value for the test.

alternative

a character string describing the alternative hypothesis.

method

the type of test applied.

contrast

a character string giving the names of the data.

contrast.index

a suffix of coefficient vector of the kkth pattern that gives modified maximum contrast statistics (row number of the coefficient matrix).

error

estimated absolute error and,

msg

status messages.

References

Nagashima, K., Sato, Y., Hamada, C. (2011). A modified maximum contrast method for unequal sample sizes in pharmacogenomic studies Stat Appl Genet Mol Biol. 10(1): Article 41. http://dx.doi.org/10.2202/1544-6115.1560

Sato, Y., Laird, N.M., Nagashima, K., et al. (2009). A new statistical screening approach for finding pharmacokinetics-related genes in genome-wide studies. Pharmacogenomics J. 9(2): 137–146. http://www.ncbi.nlm.nih.gov/pubmed/19104505

See Also

pmvt, GenzBretz, mmcm.resamp

Examples

## Example 1 ##
#  true response pattern: dominant model c=(1, 1, -2)
set.seed(136885)
x <- c(
  rnorm(130, mean =  1 / 6, sd = 1),
  rnorm( 90, mean =  1 / 6, sd = 1),
  rnorm( 10, mean = -2 / 6, sd = 1)
)
g <- rep(1:3, c(130, 90, 10))
boxplot(
  x ~ g,
  width = c(length(g[g==1]), length(g[g==2]), length(g[g==3])),
  main  = "Dominant model (sample data)",
  xlab  = "Genotype", ylab="PK parameter"
)

# coefficient matrix
# c_1: additive, c_2: recessive, c_3: dominant
contrast <- rbind(
  c(-1, 0, 1), c(-2, 1, 1), c(-1, -1, 2)
)
y <- mmcm.mvt(x, g, contrast)
y

## Example 2 ##
#  for dataframe
#  true response pattern:
#    pos = 1 dominant  model c=( 1,  1, -2)
#          2 additive  model c=(-1,  0,  1)
#          3 recessive model c=( 2, -1, -1)
set.seed(3872435)
x <- c(
  rnorm(130, mean =  1 / 6, sd = 1),
  rnorm( 90, mean =  1 / 6, sd = 1),
  rnorm( 10, mean = -2 / 6, sd = 1),
  rnorm(130, mean = -1 / 4, sd = 1),
  rnorm( 90, mean =  0 / 4, sd = 1),
  rnorm( 10, mean =  1 / 4, sd = 1),
  rnorm(130, mean =  2 / 6, sd = 1),
  rnorm( 90, mean = -1 / 6, sd = 1),
  rnorm( 10, mean = -1 / 6, sd = 1)
)
g   <- rep(rep(1:3, c(130, 90, 10)), 3)
pos <- rep(c("rsXXXX", "rsYYYY", "rsZZZZ"), each=230)
xx  <- data.frame(pos = pos, x = x, g = g)

# coefficient matrix
# c_1: additive, c_2: recessive, c_3: dominant
contrast <- rbind(
  c(-1, 0, 1), c(-2, 1, 1), c(-1, -1, 2)
)
y <- by(xx, xx$pos, function(x) mmcm.mvt(x$x, x$g,
  contrast))
y <- do.call(rbind, y)[,c(3,7,9)]
y

The permuted modified maximum contrast method

Description

This function gives PP-value for the permuted modified maximum contrast method.

Usage

mmcm.resamp(
  x,
  g,
  contrast,
  alternative = c("two.sided", "less", "greater"),
  nsample = 20000,
  abseps = 0.001,
  seed = NULL,
  nthread = 2
)

Arguments

x

a numeric vector of data values

g

a integer vector giving the group for the corresponding elements of x

contrast

a numeric contrast coefficient matrix for permuted modified maximum contrast statistics

alternative

a character string specifying the alternative hypothesis, must be one of "two.sided" (default), "greater" or "less". You can specify just the initial letter.

nsample

specifies the number of resamples (default: 20000)

abseps

specifies the absolute error tolerance (default: 0.001)

seed

a single value, interpreted as an integer; see set.seed() function. (default: NULL)

nthread

sthe number of threads used in parallel computing, or FALSE that means single threading (default: 2)

Details

mmcm.resamp performs the permuted modified maximum contrast method that is detecting a true response pattern under the unequal sample size situation.

Yij(i=1,2,;j=1,2,,ni)Y_{ij} (i=1, 2, \ldots; j=1, 2, \ldots, n_i) is an observed response for jj-th individual in ii-th group.

C\bm{C} is coefficient matrix for permuted modified maximum contrast statistics (i×ki \times k matrix, ii: No. of groups, kk: No. of pattern).

C=(c1,c2,,ck)T\bm{C}=(\bm{c}_1, \bm{c}_2, \ldots, \bm{c}_k)^{\rm{T}}

ck\bm{c}_k is coefficient vector of kk-th pattern.

ck=(ck1,ck2,,cki)T(icki=0)\bm{c}_k=(c_{k1}, c_{k2}, \ldots, c_{ki})^{\rm{T}} \qquad (\textstyle \sum_i c_{ki}=0)

MmaxM_{\max} is a permuted modified maximum contrast statistic.

Yˉi=j=1niYijni,Yˉ=(Yˉ1,Yˉ2,,Yˉi,,Yˉa)T,Mk=cktYˉcktck,\bar{Y}_i=\frac{\sum_{j=1}^{n_i} Y_{ij}}{n_{i}}, \bar{\bm{Y}}=(\bar{Y}_1, \bar{Y}_2, \ldots, \bar{Y}_i, \ldots, \bar{Y}_a)^{\rm{T}}, M_{k}=\frac{\bm{c}^t_k \bar{\bm{Y}}}{\sqrt{\bm{c}^t_k \bm{c}_k}},

Mmax=max(M1,M2,,Mk).M_{\max}=\max(M_1, M_2, \ldots, M_k).

Consider testing the overall null hypothesis H0:μ1=μ2==μiH_0: \mu_1=\mu_2=\ldots=\mu_i, versus alternative hypotheses H1H_1 for response petterns (H1:μ1<μ2<<μi,μ1=μ2<<μi,μ1<μ2<=μiH_1: \mu_1<\mu_2<\ldots<\mu_i, \mu_1=\mu_2<\ldots<\mu_i, \mu_1<\mu_2<\ldots=\mu_i). The PP-value for the probability distribution of MmaxM_{\max} under the overall null hypothesis is

P-value=Pr(Mmax>mmaxH0)P\mbox{-value}=\Pr(M_{\max}>m_{\max} \mid H_0)

mmaxm_{\max} is observed value of statistics. This function gives distribution of MmaxM_{\max} by using the permutation method, follow algorithm:

1. Initialize counting variable: COUNT=0COUNT = 0. Input parameters: NRESAMPMINNRESAMPMIN (minimum resampling count, we set 1000), NRESAMPMAXNRESAMPMAX (maximum resampling count), and ϵ\epsilon (absolute error tolerance).

2. Calculate mmaxm_{\max} that is the observed value of the test statistic.

3. Let yij(r)y_{ij}^{(r)} donate data, which are sampled without replacement, and independently, form observed value yijy_{ij}. Where, (r)(r) is suffix of the resampling number (r=1,2,)(r = 1,\, 2,\, \ldots).

4. Calculate mmax(r)m^{(r)}_{\max} from yij(r)y_{ij}^{(r)}. If mmax(r)>mmaxm^{(r)}_{\max} > m_{\max}, then increment the counting variable: COUNT=COUNT+1COUNT = COUNT + 1. Calculate approximate P-value p^(r)=COUNT/r\hat{p}^{(r)}=COUNT/r, and the simulation standard error SE(p^(r))=p^(r)(1p^(r))/rSE(\hat{p}^{(r)})=\sqrt{\hat{p}^{(r)}(1- \hat{p}^{(r)})/r}.

5. Repeat 3–4, while r>1000r > 1000 and 3.5SE(p^(r))<ϵ3.5SE(\hat{p}^{(r)}) < \epsilon (corresponding to 99% confidence level), or NRESAMPMAXNRESAMPMAX times. Output the approximate P-value p^(r)\hat{p}^{(r)}.

Value

statistic

the value of the test statistic with a name describing it.

p.value

the p-value for the test.

alternative

a character string describing the alternative hypothesis.

method

the type of test applied.

contrast

a character string giving the names of the data.

contrast.index

a suffix of coefficient vector of the kkth pattern that gives permuted modified maximum contrast statistics (row number of the coefficient matrix).

error

estimated absolute error and,

msg

status messages.

References

Nagashima, K., Sato, Y., Hamada, C. (2011). A modified maximum contrast method for unequal sample sizes in pharmacogenomic studies Stat Appl Genet Mol Biol. 10(1): Article 41. http://dx.doi.org/10.2202/1544-6115.1560

Sato, Y., Laird, N.M., Nagashima, K., et al. (2009). A new statistical screening approach for finding pharmacokinetics-related genes in genome-wide studies. Pharmacogenomics J. 9(2): 137–146. http://www.ncbi.nlm.nih.gov/pubmed/19104505

See Also

mmcm.mvt

Examples

## Example 1 ##
#  true response pattern: dominant model c=(1, 1, -2)
set.seed(136885)
x <- c(
  rnorm(130, mean =  1 / 6, sd = 1),
  rnorm( 90, mean =  1 / 6, sd = 1),
  rnorm( 10, mean = -2 / 6, sd = 1)
)
g <- rep(1:3, c(130, 90, 10))
boxplot(
  x ~ g,
  width = c(length(g[g==1]), length(g[g==2]), length(g[g==3])),
  main  = "Dominant model (sample data)",
  xlab  = "Genotype", ylab="PK parameter"
)

# coefficient matrix
# c_1: additive, c_2: recessive, c_3: dominant
contrast <- rbind(
  c(-1, 0, 1), c(-2, 1, 1), c(-1, -1, 2)
)
y <- mmcm.resamp(x, g, contrast, nsample = 20000,
                 abseps = 0.01, seed = 5784324)
y

## Example 2 ##
#  for dataframe
#  true response pattern:
#    pos = 1 dominant  model c=( 1,  1, -2)
#          2 additive  model c=(-1,  0,  1)
#          3 recessive model c=( 2, -1, -1)
set.seed(3872435)
x <- c(
  rnorm(130, mean =  1 / 6, sd = 1),
  rnorm( 90, mean =  1 / 6, sd = 1),
  rnorm( 10, mean = -2 / 6, sd = 1),
  rnorm(130, mean = -1 / 4, sd = 1),
  rnorm( 90, mean =  0 / 4, sd = 1),
  rnorm( 10, mean =  1 / 4, sd = 1),
  rnorm(130, mean =  2 / 6, sd = 1),
  rnorm( 90, mean = -1 / 6, sd = 1),
  rnorm( 10, mean = -1 / 6, sd = 1)
)
g   <- rep(rep(1:3, c(130, 90, 10)), 3)
pos <- rep(c("rsXXXX", "rsYYYY", "rsZZZZ"), each = 230)
xx  <- data.frame(pos = pos, x = x, g = g)

# coefficient matrix
# c_1: additive, c_2: recessive, c_3: dominant
contrast <- rbind(
  c(-1, 0, 1), c(-2, 1, 1), c(-1, -1, 2)
)

y <- by(xx, xx$pos, function(x) mmcm.resamp(x$x, x$g,
  contrast, abseps = 0.02, nsample = 10000))
y <- do.call(rbind, y)[,c(3,7,9)]
y

Print function for mmcm object

Description

This function print result of function mcm.mvt, mmcm.mvt and mmcm.resamp

Usage

## S3 method for class 'mmcm'
print(x, digits = getOption("digits"), ...)

Arguments

x

Object of class mmcm, which is result of function mcm.mvt, mmcm.mvt and mmcm.resamp.

digits

a non-null value for digits specifies the minimum number of significant digits to be printed in values. The default, NULL, uses getOption(digits). (For the interpretation for complex numbers see signif.) Non-integer values will be rounded down, and only values greater than or equal to 1 and no greater than 22 are accepted.

...

Further arguments passed to or from other methods.

Details

The case where printed "More than 2 contrast coefficient vectors were selected", some contrast may be unsuitable.

See Also

print.default, mmcm.mvt, mmcm.resamp, mcm.mvt