The hardware and bandwidth for this mirror is donated by METANET, the Webhosting and Full Service-Cloud Provider.
If you wish to report a bug, or if you are interested in having us mirror your free-software or open-source project, please feel free to contact us at mirror[@]metanet.ch.
Here we’re checking the sparse-matrix version of pQF
on a really unsuitably small example with 67 markers, because it’s the one that comes with the SKAT
package: see help(SKAT)
library(SKAT) #CRAN
## Loading required package: Matrix
## Loading required package: SPAtest
library(bigQF) #github/tslumley
set.seed(2018-5-18)
First example: continuous phenotype, no adjustment
data(SKAT.example)
attach(SKAT.example) #look, it's not my fault, that's how they did it.
<-SKAT_Null_Model(y.c ~ 1, out_type="C")
obj<-SKAT(Z, obj)
skat.out1<-SKAT.matrixfree(Z)
skat.qf1a<-SKAT.matrixfree(Z,model=lm(y.c~1))
skat.qf1b<-SKAT.matrixfree(Z,model=glm(y.c~1))
skat.qf1c
$Q skat.out1
## [,1]
## [1,] 234803.8
$Q(y.c) skat.qf1a
## [,1]
## [1,] 234803.8
$Q() ## phenotype used in fitting skat.qf1b
## [1] 234803.8
$Q(y.c) ## new phenotype skat.qf1b
## [1] 234803.8
$p.value skat.out1
## [1] 0.01874576
pQF(skat.out1$Q,skat.qf1a,neig=60,convolution.method="integration" )
## [,1]
## [1,] 0.01874576
pQF(skat.out1$Q,skat.qf1b,neig=60,convolution.method="integration" )
## Warning in pchisqsum(x, c(rep(1, n), nu), c(ee, scale), method = method, :
## Negative/fractional df removed
## [,1]
## [1,] 0.01874551
pQF(skat.out1$Q,skat.qf1c,neig=60,convolution.method="integration" )
## Warning in pchisqsum(x, c(rep(1, n), nu), c(ee, scale), method = method, :
## Negative/fractional df removed
## [,1]
## [1,] 0.01874551
The warning indicates the remainder term in the approximation has been dropped, which is appropriate. If you don’t specify convolution.method
the default is the saddlepoint approximation – the impact is in the third decimal place.
And more systematically
set.seed(2018-5-18)
<-lapply(1:65, function(k) pQF(skat.out1$Q, skat.qf1a, neig=k,
pconvolution.method="integration",tr2.sample.size=1000 )
)<-data.frame(p=do.call(c,p),k=1:65)
pdfplot(p~k,data=pdf,pch=19,col="orange", ylim=c(0.017,0.020))
abline(h=skat.out1$p.value,lty=2)
These binaries (installable software) and packages are in development.
They may not be fully stable and should be used with caution. We make no claims about them.