我想用一个包含函数与矩阵mapply使用mapply使用的,如果是这样的:符合条件
dim_rf <- 10
rf <- matrix(runif(dim_rf*dim_rf),ncol=dim_rf)
fire_rf <- function(i,j) {
if(rf[i,j+1] + rf[i+1,j] + rf[i,j-1] + rf[i-1,j]>1)
rf[i,j] <-2
}
mapply(fire_rf, row(rf), col(rf) )
,但它给出了一个错误
Error en if (rf[i, j + 1] + rf[i + 1, j] + rf[i, j - 1] + rf[i - 1, j] > :
参数长度为零
我怎么能修改功能,使其工作?
我用这个做火渗透的一个简单的模型,因此需要快速,因为100或1000
您应该增加像一些条件'如果(I> 1&J> 1&I
agstudy
当'j'或'i'是'1',您尝试使用子集零为索引元素'rf'。当'j'或'i'是等于最大列或行号,该索引也最终被'rf'之外。这在“if”语句中作为错误结束。所以不要在'mapply'迭代中包含这些“边缘”情况。 – BenBarnes
代码的点是产生副作用。因此,只需使用'for'循环即可。 –