################################################### ### chunk number 1: options ################################################### #line 83 "vignettes/GeneticsPed/inst/doc/quanGenAnimalModel.Rnw" options(width=85) ################################################### ### chunk number 2: data ################################################### #line 190 "vignettes/GeneticsPed/inst/doc/quanGenAnimalModel.Rnw" library(GeneticsPed) data(Mrode3.1) (x <- Pedigree(x=Mrode3.1, subject="calf", ascendant=c("sire", "dam"), ascendantSex=c("Male", "Female"), sex="sex")) ################################################### ### chunk number 3: y ################################################### #line 215 "vignettes/GeneticsPed/inst/doc/quanGenAnimalModel.Rnw" (y <- x$pwg) ################################################### ### chunk number 4: X ################################################### #line 221 "vignettes/GeneticsPed/inst/doc/quanGenAnimalModel.Rnw" X <- model.matrix(~ x$sex - 1) t(X) ################################################### ### chunk number 5: Z ################################################### #line 231 "vignettes/GeneticsPed/inst/doc/quanGenAnimalModel.Rnw" (Z <- model.matrix(object=x, y=x$pwg, id=x$calf)) ################################################### ### chunk number 6: LHS ################################################### #line 237 "vignettes/GeneticsPed/inst/doc/quanGenAnimalModel.Rnw" LHS <- rbind(cbind(t(X) %*% X, t(X) %*% Z), cbind(t(Z) %*% X, t(Z) %*% Z)) ## or more efficiently (LHS <- rbind(cbind(crossprod(X), crossprod(X, Z)), cbind(crossprod(Z, X), crossprod(Z)))) ################################################### ### chunk number 7: LHS2 ################################################### #line 248 "vignettes/GeneticsPed/inst/doc/quanGenAnimalModel.Rnw" ## We want Ainv for all individuals in the pedigree not only individuals ## with records x <- extend(x) Ainv <- inverseAdditive(x=x) sigma2a <- 20 sigma2e <- 40 alpha <- sigma2e / sigma2a q <- nIndividual(x) p <- nrow(LHS) - q (LHS[(p + 1):(p + q), (p + 1):(p + q)] <- LHS[(p + 1):(p + q), (p + 1):(p + q)] + Ainv * alpha) ################################################### ### chunk number 8: RHS ################################################### #line 264 "vignettes/GeneticsPed/inst/doc/quanGenAnimalModel.Rnw" RHS <- rbind(t(X) %*% y, t(Z) %*% y) ## or more efficiently RHS <- rbind(crossprod(X, y), crossprod(Z, y)) t(RHS) ################################################### ### chunk number 9: solve ################################################### #line 275 "vignettes/GeneticsPed/inst/doc/quanGenAnimalModel.Rnw" sol <- solve(LHS) %*% RHS ## or more efficiently sol <- solve(LHS, RHS) t(sol) ################################################### ### chunk number 10: sessionInfo ################################################### #line 288 "vignettes/GeneticsPed/inst/doc/quanGenAnimalModel.Rnw" toLatex(sessionInfo())