1

我编写了以下代码,它应该生成一个 1 行 10 列的输出矩阵。nchrom在我通过将标签替换为来纠正循环之前,这确实可以正常工作q,但现在会生成以下错误代码:

Error in rmultinom(1, size * q/2, prob = c(num_chrom)) : 
  no positive probabilities

如果有人可以帮助我确定代码中的问题所在,我将不胜感激。我目前的代码如下:

randomdiv <- function(nchrom, ndivs, size) {
  chrom <- matrix(nrow = 1, ncol = ndivs)
 {q <- nchrom
  for (i in 1:ndivs)
  {
  {sz <- matrix(nrow = nchrom, ncol = ndivs)          
   for (j in 1:nchrom) {
    n <- size
  for (i in 1:ndivs)
  {
    old_subs <- rbinom (1, n, 0.5)          #roughly halving the number of subunits per chromosome, representing segregation of chromosomes
    num_chrom <- rep(1 / q, q)    #vector to determine probabilities for multinomial - based on number of chromosomes per cell 
    new_subs <- rmultinom(1, size * q / 2, prob = c(num_chrom))     #multinomial to generate randomness in number of new subunits translated per cell (based on ideal being half of the total subunit pool)

    total_subs <- cbind(old_subs, new_subs)    #required step to allow ifelse function to properly work on individual rows
    m <- as.matrix(ifelse(total_subs[,1]>0, total_subs[,1] + total_subs[,2], total_subs[,1]))  #ifelse function to ensure that if a chromosome reaches 0 subunits, there will be no new subunits added to that chromosom

    zeros <- colSums(m==0)     #calculates number of zeros in the columns of m and will form a vector (2 values will be shown - only interested in the first for m[1,1])
    k <- c(-1, 1)
    s <- sample(k, zeros[1], replace = TRUE)  #random samples taken from -1 and  - number of samples is equal to the number of zeros that have occurred 
    new_nchrom <- q + sum(s)   #Sum of samples determines the number of chromosomes to add or remove from the cell (random element)

    chrom[,i] <- new_nchrom    #Inserts new number of chromosomes into the matrix for output
    q <- new_nchrom

    sz[j,i] <- m[1,1]      #puts in m matrix as the next column in sz matrix - need to keep a matrix of subunit numbers because the number of subunits reaching 0 determines changes in chromosome number
    n <- m
  }
}
}
 }
 }
 return (chrom)
 }

>randomdiv(10, 10, 3)
4

0 回答 0