SKATBinary | R Documentation |
This function computes p-values of Burden test, SKAT, and SKAT-O for binary traits using asymptotic and efficient resampling methods.
SKATBinary(Z, obj, kernel = "linear.weighted", method="SKAT" , method.bin="Hybrid", weights.beta=c(1,25), weights = NULL , r.corr=0, impute.method = "bestguess", is_check_genotype=TRUE , is_dosage = FALSE, missing_cutoff=0.15, max_maf=1 , estimate_MAF=1, N.Resampling=2 *10^6, seednum=100, epsilon=10^-6 , SetID=NULL) SKATBinary.SSD.OneSet(SSD.INFO, SetID, obj, ... ,obj.SNPWeight=NULL) SKATBinary.SSD.OneSet_SetIndex(SSD.INFO, SetIndex, obj, ... ,obj.SNPWeight=NULL)
Z |
a numeric genotype matrix with each row as a different individual and each column as a separate gene/snp. Each genotype should be coded as 0, 1, 2, and 9 (or NA) for AA, Aa, aa, and missing, where A is a major allele and a is a minor allele. |
obj |
output object from SKAT_Null_Model. |
kernel |
type of kernel (default= "linear.weighted"). See SKAT page for details. |
method |
type of gene based test (default= "SKAT"). The possible choices are "SKAT", "Burden" and "SKATO", which represents SKAT, Burden and SKAT-O tests, respectively. This parameter differs from the "method" parameter in SKAT function. "Burden" is equivalent to method="davies" and r.corr=1 and "SKATO" is equivalent to method="optimal.adj" in the SKAT function. When method="Burden" or method="SKATO", r.corr will be ignored. |
method.bin |
type of method to compute a p-value (default="Hybrid"). Possible choices are "Hybrid", "ER", "ER.A", "QA", "MA" and "UA". See details |
weights.beta |
a numeric vector of parameters of beta weights. It is only used for weighted kernels. If you want to use your own weights, please specify the “weights” parameter. |
weights |
a numeric vector of weights for the weighted kernels. See SKAT page for details. |
impute.method |
a method to impute missing genotypes (default= "bestguess"). "bestguess" imputes missing genotypes as most likely values (0,1,2), "random" imputes missing genotypes by generating binomial(2,p) random variables (p is the MAF), and "fixed" imputes missing genotypes by assigning the mean genotype value (2p). |
r.corr |
the ρ parameter for the compound symmetric correlation structure kernel (default= 0). If it is a vector, SKAT will conduct the optimal test. It is ignored when method="Burden" or method="SKATO". |
is_check_genotype |
a logical value indicating whether to check the validity of the genotype matrix Z (default= TRUE). See SKAT page for details. |
is_dosage |
a logical value indicating whether the matrix Z is a dosage matrix. If it is TRUE, SKAT will ignore “is_check_genotype”. |
missing_cutoff |
a cutoff of the missing rates of SNPs (default=0.15). Any SNPs with missing rates higher than the cutoff will be excluded from the analysis. |
max_maf |
a cutoff of the maximum minor allele frequencies (MAF) (default=1, no cutoff). Any SNPs with MAF > cutoff will be excluded from the analysis. |
estimate_MAF |
a numeric value indicating how to estimate MAFs for the weight calculation and the missing genotype imputation. See SKAT page for details. |
N.Resampling |
a number of resampling to be conducted to get p-values (default=2 *10^6). |
seednum |
a seed number for random number generation (default=100). If NULL, no seed number will be assigned. |
epsilon |
a precision level (default=10^-6). |
SSD.INFO |
an SSD_INFO object returned from Open_SSD. |
SetID |
a character value of Set ID. You can find a set ID of each set from SetInfo object of SSD.INFO. In SKATBinary function, this parameter is for the internal use only. |
SetIndex |
a numeric value of Set index. You can find a set index of each set from SetInfo object of SSD.INFO |
... |
further arguments to be passed to “SKATBinary” |
obj.SNPWeight |
an output object of Read_SNP_WeightFile (default=NULL). If NULL, the beta weight with the “weights.beta” parameter will be used. |
This function implements six methods (method.bin) to compute p-values: 1) Efficient resampling (ER); 2) Quantile adjusted moment matching (QA); 3) Moment matching adjustment (MA); 4) No adjustment (UA); 5) Adaptive ER (ER.A); and 6) Hybrid. "Hybrid" selects a method based on the total minor allele count (MAC), the number of individuals with minor alleles (m), and the degree of case-control imbalance. When method.bin="ER" or "ER.A", SKATBinary compute mid-p-values and minimum achievable mid p-values.
If seednum is not NULL, set.seed(seednum) function is used to specify seeds to get the same p-values of ER based methods for different runs. Therefore, please set seednum=NULL, if you do not want to set seeds.
SKATBinary uses impute.method="bestguess" as a default method for the imputation, which is different from SKAT that uses impute.method="fixed" as a default method. We changed it because SKATBinary with impute.method="fixed" can yield false positives when variates are very rare and missing rates between cases and controls are unbalanced. When missing rates between cases and controls are highly unbalanced, SKAT impute.method="fixed" can also yield false positives, but it happens less likely. So we did not change the default imputation method in SKAT.
p.value |
p-value. It will be the mid p-value if ER or ER.A are used to compute the p-value. |
p.value.standard |
(ER and ER.A only) standard p-value. |
p.value.resampling |
p-values from resampled outcome. You can obtain it when n.Resampling (in SKAT_Null_Model) > 0. See SKAT_Null_Model page. |
p.value.standard.resampling |
(ER and ER.A only)standard p-values from resampled outcomes. |
m |
the number of individuals with minor alleles. |
MAP |
minimum possible p-values. It is available when the method.bin="ER" and m is sufficiently small. |
MAC |
total minor allele count (MAC). |
n.total |
(ER only) the number of resampling to be generated to get the p-value. It can be smaller than N.Resampling when the total number of configurations of case-controls among individuals with minor alleles are smaller than N.Resampling. |
is.accurate |
logical value for the accuracy of the p-value. If it is false, more resampling is needed to accurately estimate the p-value. |
param$n.marker |
a number of SNPs in the genotype matrix |
param$n.marker.test |
a number of SNPs used for the test. It can be different from param$n.marker when some markers are monomorphic or have higher missing rates than the missing_cutoff. |
method.bin |
a type of method to be used to compute the p-value. |
test.snp.mac |
a vector of minor allele count (MAC) of the snps tested. The name is SNP-ID. |
Seunggeun Lee
Lee, S., Fuchsberger, C., Kim, S., Scott, L. (2015) An efficient resampling method for calibrating single and gene-based rare variant association analysis in case-control studies. Biostatistics, in press.
data(SKATBinary.example) Z<-SKATBinary.example$Z obj<-SKAT_Null_Model(y ~ x1 + x2, out_type="D", data=SKATBinary.example) # run SKAT (default method) with Hybrid out = SKATBinary(Z, obj) # p-value out$p.value # MAP out$MAP # method used to compute p-value (method.bin) out$method.bin # # Run burden and SKAT-O with Hybrid SKATBinary(Z, obj, method="Burden")$p.value SKATBinary(Z, obj, method="SKATO")$p.value # # Run with SKAT-QA, -MA and -UA SKATBinary(Z, obj, method.bin="QA")$p.value SKATBinary(Z, obj, method.bin="MA")$p.value SKATBinary(Z, obj, method.bin="UA")$p.value # UA from SKAT function SKAT(Z, obj)$p.value # # Run with Adaptive ER out =SKATBinary(Z, obj, method.bin="ER.A") out$p.value # the number of total resampling is smaller than 2*10^6 (default value) out$n.total
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.