R/sim_ril.R

Defines functions sim_ri8 sim_ri2

## sim_ril.R

# these functions aren't very good
sim_ri2 <-
    function(L, n.gen=20, m=10, p=0, selfing=FALSE,
             obligate_chiasma=FALSE)
{
    if(obligate_chiasma) Lstar <- calc_Lstar(L, m, p)
    else Lstar <- L

    f1 <- create_parent(L,c(1,2))
    par1 <- cross(f1,f1,m,p)

    if(selfing) par2 <- par1
    else par2 <- cross(f1,f1,m,p, obligate_chiasma, Lstar)

    for(i in 1:n.gen) {
        c1 <- cross(par1,par2,m,p, obligate_chiasma, Lstar)
        if(selfing)
            par1 <- par2 <- c1
        else {
            c2 <- cross(par1,par2,m,p, obligate_chiasma, Lstar)
            par1 <- c1
            par2 <- c2
        }
    }
    par1
}

sim_ri8 <-
    function(L, n.gen=20, m=10, p=0, selfing=FALSE,
             obligate_chiasma=FALSE)
{
    if(obligate_chiasma) Lstar <- calc_Lstar(L, m, p)
    else Lstar <- L

    f1a <- create_parent(L,c(1,2))
    f1b <- create_parent(L,c(3,4))
    f1c <- create_parent(L,c(5,6))
    f1d <- create_parent(L,c(7,8))
    par1 <- cross(f1a,f1b,m,p, obligate_chiasma, Lstar)

    if(selfing) par2 <- par1
    else par2 <- cross(f1c,f1d,m,p, obligate_chiasma, Lstar)

    if(length(n.gen)==1) {
        for(i in 1:(n.gen+1)) {
            c1 <- cross(par1,par2,m,p, obligate_chiasma, Lstar)
            if(selfing)
                par1 <- par2 <- c1
            else {
                c2 <- cross(par1,par2,m,p, obligate_chiasma, Lstar)
                par1 <- c1
                par2 <- c2
            }
        }
        return(par1)
    }
    else {
        result <- vector("list",length(n.gen))
        names(result) <- n.gen
        n.gen <- c(-1,n.gen)
        for(j in 2:length(n.gen)) {
            for(i in (n.gen[j-1]+2):(n.gen[j]+1)) {
                c1 <- cross(par1,par2,m,p, obligate_chiasma, Lstar)
                if(selfing)
                    par1 <- par2 <- c1
                else {
                    c2 <- cross(par1,par2,m,p, obligate_chiasma, Lstar)
                    par1 <- c1
                    par2 <- c2
                }
            }
            result[[j-1]] <- par1
        }
        return(result)
    }

}
kbroman/simcross documentation built on Jan. 13, 2024, 10:31 p.m.