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

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

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==