Problem 1: Inverse Numerator Relationship Matrix
During the lecture the method of computing the inverse numerator
relationship matrix \(A^{-1}\) directly
was introduced. The computation is based on the LDL-decomposition. As a
result, we can write
\[A^{-1} = (L^T)^{-1} \cdot D^{-1} \cdot
L^{-1}\] where \(L^{-1} = I-P\),
and \(D^{-1}\) is a diagonal matrix
with \((D^{-1})_{ii} * \sigma_u^{-2} =
var(m_i)^{-1}\).
Tasks
- Use the example pedigree given below and compute the matrices \(L^{-1}\) and \(D^{-1}\) to compute \(A^{-1}\)
- Verify your result using the function
getAinv()
from
package pedigreemm.
Pedigree
nr_animal <- 6
tbl_pedigree <- tibble::tibble(Calf = c(1:nr_animal),
Sire = c(NA, NA, NA, 1 ,3, 4),
Dam = c(NA, NA, NA, 2, 2, 5))
tbl_pedigree
Your Solution
- Construct matrix P from the pedigree
- Use matrix P to compute the matrix \(L^{-1}\)
- Construct the matrix \(D^{-1}\)
- Compute \(A^{-1}\) based on \(L^{-1}\) and \(D^{-1}\)
Problem 2: Rules
The following diagram helps to illustrate the rules for constructing
\(A^{-1}\)
Tasks
- Go through the list of animals in the pedigree and write down the
contributions that are made to the different elements of matrix \(A^{-1}\)
- Based on the different contributions, try to come up with some
general rules
Your Solution
Problem 3: Program using the Rules
Write a program in R that implements the rules found in the solution
of Problem 2. Test your program with the pedigree given in Problem 1.
Compare the results that you obtain with the result obtained from the
function pedigreemm::getAinv()
.
Your Solution
- Because the focus of this problem is the implementation of
Henderson’s rules in a function, we use then function
pedigreemm::Dmat()
to obtain the values of the matrix \(D\).
- Write a function
get_A_inverse
which takes as input a
pedigree and that returns the inverse numerator relationship matrix
Latest Changes: 2023-11-24 14:57:37 (pvr)
LS0tCnRpdGxlOiBMaXZlc3RvY2sgQnJlZWRpbmcgYW5kIEdlbm9taWNzIC0gTm90ZWJvb2sgMTAKYXV0aG9yOiBQZXRlciB2b24gUm9ocgpkYXRlOiAnMjAyMy0xMS0yNCcKb3V0cHV0OiBodG1sX25vdGVib29rCnBhcmFtczoKICBkb2N0eXBlOgogICAgbGFiZWw6IERvY3VtZW50IFR5cGUKICAgIHZhbHVlOiBzb2x1dGlvbgogICAgY2hvaWNlczoKICAgIC0gZXhlcmNpc2UKICAgIC0gc29sdXRpb24KICAgIC0gbm90ZWJvb2sKICBpc29ubGluZToKICAgIGxhYmVsOiBPbmxpbmUgKHkvbikKICAgIHZhbHVlOiB0cnVlCiAgICBjaG9pY2VzOgogICAgLSB0cnVlCiAgICAtIGZhbHNlCi0tLQoKCgpgYGB7ciBzZXR1cCwgaW5jbHVkZT1GQUxTRX0Ka25pdHI6Om9wdHNfY2h1bmskc2V0KGVjaG8gPSBUUlVFKQprbml0cjo6a25pdF9ob29rcyRzZXQoaG9va19jb252ZXJ0X29kZyA9IHJtZGhlbHA6Omhvb2tfY29udmVydF9vZGcpCmBgYAoKCiMjIFByb2JsZW0gMTogSW52ZXJzZSBOdW1lcmF0b3IgUmVsYXRpb25zaGlwIE1hdHJpeApEdXJpbmcgdGhlIGxlY3R1cmUgdGhlIG1ldGhvZCBvZiBjb21wdXRpbmcgdGhlIGludmVyc2UgbnVtZXJhdG9yIHJlbGF0aW9uc2hpcCBtYXRyaXggJEFeey0xfSQgZGlyZWN0bHkgd2FzIGludHJvZHVjZWQuIFRoZSBjb21wdXRhdGlvbiBpcyBiYXNlZCBvbiB0aGUgTERMLWRlY29tcG9zaXRpb24uIEFzIGEgcmVzdWx0LCB3ZSBjYW4gd3JpdGUgCgokJEFeey0xfSA9IChMXlQpXnstMX0gXGNkb3QgRF57LTF9IFxjZG90IExeey0xfSQkCndoZXJlICRMXnstMX0gPSBJLVAkLCBhbmQgJEReey0xfSQgaXMgYSBkaWFnb25hbCBtYXRyaXggd2l0aCAkKEReey0xfSlfe2lpfSAqIFxzaWdtYV91XnstMn0gPSB2YXIobV9pKV57LTF9JC4gIAoKCiMjIFRhc2tzCgoqIFVzZSB0aGUgZXhhbXBsZSBwZWRpZ3JlZSBnaXZlbiBiZWxvdyBhbmQgY29tcHV0ZSB0aGUgbWF0cmljZXMgJExeey0xfSQgYW5kICREXnstMX0kIHRvIGNvbXB1dGUgJEFeey0xfSQKKiBWZXJpZnkgeW91ciByZXN1bHQgdXNpbmcgdGhlIGZ1bmN0aW9uIGBnZXRBaW52KClgIGZyb20gcGFja2FnZSBwZWRpZ3JlZW1tLgoKCiMjIFBlZGlncmVlCgpgYGB7cn0KbnJfYW5pbWFsIDwtIDYKdGJsX3BlZGlncmVlIDwtIHRpYmJsZTo6dGliYmxlKENhbGYgPSBjKDE6bnJfYW5pbWFsKSwKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFNpcmUgPSBjKE5BLCBOQSwgTkEsIDEgLDMsIDQpLAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgRGFtID0gYyhOQSwgTkEsIE5BLCAyLCAyLCA1KSkKdGJsX3BlZGlncmVlCmBgYAoKCiMjIyBZb3VyIFNvbHV0aW9uCgoqIENvbnN0cnVjdCBtYXRyaXggUCBmcm9tIHRoZSBwZWRpZ3JlZQoqIFVzZSBtYXRyaXggUCB0byBjb21wdXRlIHRoZSBtYXRyaXggJExeey0xfSQKKiBDb25zdHJ1Y3QgdGhlIG1hdHJpeCAkRF57LTF9JAoqIENvbXB1dGUgJEFeey0xfSQgYmFzZWQgb24gJExeey0xfSQgYW5kICREXnstMX0kCgoKCgoKIyMgUHJvYmxlbSAyOiBSdWxlcwpUaGUgZm9sbG93aW5nIGRpYWdyYW0gaGVscHMgdG8gaWxsdXN0cmF0ZSB0aGUgcnVsZXMgZm9yIGNvbnN0cnVjdGluZyAkQV57LTF9JAoKYGBge3IgaW52LW51bS1tYXQsIGVjaG89RkFMU0UsIGhvb2tfY29udmVydF9vZGc9VFJVRSwgZmlnX3BhdGg9Im9kZyIsIG91dC53aWR0aD0iMTAwJSJ9CiNybWRoZWxwOjp1c2Vfb2RnX2dyYXBoaWMocHNfcGF0aCA9ICJvZGcvaW52LW51bS1tYXQub2RnIikKa25pdHI6OmluY2x1ZGVfZ3JhcGhpY3MocGF0aCA9ICJvZGcvaW52LW51bS1tYXQucG5nIikKYGBgCiAKCiMjIFRhc2tzCgoqIEdvIHRocm91Z2ggdGhlIGxpc3Qgb2YgYW5pbWFscyBpbiB0aGUgcGVkaWdyZWUgYW5kIHdyaXRlIGRvd24gdGhlIGNvbnRyaWJ1dGlvbnMgdGhhdCBhcmUgbWFkZSB0byB0aGUgZGlmZmVyZW50IGVsZW1lbnRzIG9mIG1hdHJpeCAkQV57LTF9JCAKKiBCYXNlZCBvbiB0aGUgZGlmZmVyZW50IGNvbnRyaWJ1dGlvbnMsIHRyeSB0byBjb21lIHVwIHdpdGggc29tZSBnZW5lcmFsIHJ1bGVzCgoKIyMjIFlvdXIgU29sdXRpb24KCgoKCgojIyBQcm9ibGVtIDM6IFByb2dyYW0gdXNpbmcgdGhlIFJ1bGVzCldyaXRlIGEgcHJvZ3JhbSBpbiBSIHRoYXQgaW1wbGVtZW50cyB0aGUgcnVsZXMgZm91bmQgaW4gdGhlIHNvbHV0aW9uIG9mIFByb2JsZW0gMi4gVGVzdCB5b3VyIHByb2dyYW0gd2l0aCB0aGUgcGVkaWdyZWUgZ2l2ZW4gaW4gUHJvYmxlbSAxLiBDb21wYXJlIHRoZSByZXN1bHRzIHRoYXQgeW91IG9idGFpbiB3aXRoIHRoZSByZXN1bHQgb2J0YWluZWQgZnJvbSB0aGUgZnVuY3Rpb24gYHBlZGlncmVlbW06OmdldEFpbnYoKWAuCgoKIyMjIFlvdXIgU29sdXRpb24KCiogQmVjYXVzZSB0aGUgZm9jdXMgb2YgdGhpcyBwcm9ibGVtIGlzIHRoZSBpbXBsZW1lbnRhdGlvbiBvZiBIZW5kZXJzb24ncyBydWxlcyBpbiBhIGZ1bmN0aW9uLCB3ZSB1c2UgdGhlbiBmdW5jdGlvbiBgcGVkaWdyZWVtbTo6RG1hdCgpYCB0byBvYnRhaW4gdGhlIHZhbHVlcyBvZiB0aGUgbWF0cml4ICREJC4gCiogV3JpdGUgYSBmdW5jdGlvbiBgZ2V0X0FfaW52ZXJzZWAgd2hpY2ggdGFrZXMgYXMgaW5wdXQgYSBwZWRpZ3JlZSBhbmQgdGhhdCByZXR1cm5zIHRoZSBpbnZlcnNlIG51bWVyYXRvciByZWxhdGlvbnNoaXAgbWF0cml4CgoKCiAKCgpgYGB7ciwgZWNobz1GQUxTRSwgcmVzdWx0cz0nYXNpcyd9CmNhdCgnXG4tLS1cblxuIF9MYXRlc3QgQ2hhbmdlczogJywgZm9ybWF0KFN5cy50aW1lKCksICclWS0lbS0lZCAlSDolTTolUycpLCAnICgnLCBTeXMuaW5mbygpWyd1c2VyJ10sICcpX1xuJywgc2VwID0gJycpCmBgYAogCg==