我正在尝试使用for循环填充4D数组,但不断出现以下错误:
no dimnames attribute for array
已经问过一个类似的问题(Error: no 'dimnames' attribute when trying to assign to array),但是我并没有真正理解答案,因此非常欢迎您提供任何帮助!
我的代码:
RESULTS1=array(0,dim=c(3,3,40,3))
dimnames(RESULTS1)<-list(c(1,2,3), c(1,2,3), c(1:40), c("J4", "NC", "ND"))
for(i in c("J4", "NC", "ND")){
RESk=array(0,dim=c(3,3,40))
M.sub<-subset(Markov.time, Grid.short==i)
if(length(M.sub[,1])>1){
for(x in 4:43){
time.dep<-M.sub[,c(x,x+1)]
RESk[,,(x-3)]<-apply(apply(time.dep,1,FUN = (MC_Matrix)),1,sum) }}
RESULTS1[,,, i]<-RESk
}
我正在使用的功能:
MC_Matrix <- function(X) {
n <- length(X)
neg.neg <- 0
neg.null <- 0
neg.pos <- 0
null.null <- 0
null.neg <-0
null.pos <- 0
pos.neg <- 0
pos.null <- 0
pos.pos <- 0
for (i in 1:(n-1)) {
if ((X[i]<0) & (X[i+1]<0)) {neg.neg <- neg.neg+1}
if (X[i]<0 & X[i+1]==0) {neg.null <- neg.null+1}
if (X[i]<0 & X[i+1]>0) {neg.pos <- neg.pos+1}
if (X[i]==0 & X[i+1]<0) {null.neg <- null.neg+1}
if (X[i]==0 & X[i+1]==0) {null.null <- null.null+1}
if (X[i]==0 & X[i+1]>0) {null.pos <- null.pos+1}
if (X[i]>0 & X[i+1]<0) {pos.neg <- pos.neg+1}
if (X[i]>0 & X[i+1]==0) {pos.null <- pos.null+1}
if (X[i]>0 & X[i+1]>0) {pos.pos <- pos.pos+1}
}
A <- matrix(c(neg.neg,null.neg,pos.neg,neg.null,null.null,pos.null,neg.pos,null.pos,pos.pos),3,3)
return(A)
}
我的数据的一部分:
Markov.time<-structure(list(Grid.short = structure(c(5L, 4L, 5L, 6L), .Label = c("",
"C7", "J2", "J4", "NC", "ND", "NG", "NH", "NK", "NM", "NN", "NO",
"NR", "NS", "NT", "NU", "NX", "NY", "NZ", "SC", "SD", "SH", "SK",
"SM", "SN", "SO", "SP", "SR", "SS", "ST", "SU", "SW", "SX", "SY",
"SZ", "TF", "TG", "TL", "TQ"), class = "factor"), Site = c(49L,
92L, 141L, 2619L), X1976 = c(1.255272505, 0, 0, 0), X1977 = c(-0.109144469,
0, 0, 0), X1978 = c(-1.146128036, 2.100370545, 0, 0), X1979 = c(0.954242509,
-0.595220567, 0, 0), X1980 = c(0.22184875, -0.550907469, 0, 0
), X1981 = c(0.146128036, 0.425968732, 0, 0), X1982 = c(0.15490196,
0.187990482, 0, 0), X1983 = c(0.505149978, 0.270647367, 0, 0),
X1984 = c(-0.477121255, -0.692721055, 0, 0), X1985 = c(-0.425968732,
0.345233658, 0, 0), X1986 = c(-0.176091259, -0.014240439,
0, 0), X1987 = c(0.176091259, 0.293730757, 0, 0), X1988 = c(-0.380211242,
-0.127399335, 0, 1.301029996), X1989 = c(0.079181246, -0.181054679,
0, 0.352182518), X1990 = c(-0.77815125, -0.064457989, 1.278753601,
-0.040428657), X1991 = c(0, -0.22184875, 0.152610163, 0.391537517
), X1992 = c(0, -0.062147907, -0.431363764, -0.24089338),
X1993 = c(0, -0.072550667, -1, -0.348454646), X1994 = c(0,
-0.087150176, 0.301029996, 0.176091259), X1995 = c(0, 0.191885526,
0.653212514, -0.159700843), X1996 = c(0, 0.397940009, -0.176091259,
-1.431363764), X1997 = c(0, -0.146128036, 0.176091259, 0),
X1998 = c(0, -0.318758763, -0.051152522, 0), X1999 = c(0,
0.199572355, 0.138302698, 0), X2000 = c(0, -0.102662342,
0.162727297, 2), X2001 = c(0, -0.062147907, 0.375663614,
-0.585026652), X2002 = c(0, 0.09017663, -0.181843588, 0.423875743
), X2003 = c(0, -0.301029996, -1.096910013, -0.608400169),
X2004 = c(0, 0.588271707, 0.903089987, 0.131278915), X2005 = c(0,
0.099702913, 0.051152522, 0.370665924), X2006 = c(0, 0.208275942,
0.159700843, 0.191885526), X2007 = c(0, -0.336942552, 0.411101455,
-0.447158031), X2008 = c(0, -0.617299958, -0.077886776, -0.045757491
), X2009 = c(0, 1.063386979, -0.229674087, 0.031034234),
X2010 = c(0, -0.102305045, -0.56427143, -0.383216752), X2011 = c(0,
-0.343781976, -0.954242509, 0.425968732), X2012 = c(0, 0.227798082,
0, -1.505149978), X2013 = c(0, 0.008773924, 0, 0), X2014 = c(0,
0.086359831, 0, 0), X2015 = c(0, -0.370356487, 0, 0), X2016 = c(0,
0.116505569, 0, 0)), .Names = c("Grid.short", "Site", "X1976",
"X1977", "X1978", "X1979", "X1980", "X1981", "X1982", "X1983",
"X1984", "X1985", "X1986", "X1987", "X1988", "X1989", "X1990",
"X1991", "X1992", "X1993", "X1994", "X1995", "X1996", "X1997",
"X1998", "X1999", "X2000", "X2001", "X2002", "X2003", "X2004",
"X2005", "X2006", "X2007", "X2008", "X2009", "X2010", "X2011",
"X2012", "X2013", "X2014", "X2015", "X2016"), row.names = c(14L,
26L, 37L, 150L), class = "data.frame")
对于此问题的解决方案,以及对问题的初学者的简单说明,我将不胜感激。
非常感谢您!
答案 0 :(得分:0)
看起来您在内部for循环中从4运行到43,但是您的数据似乎有43个变量,并且x + 1超出范围。
您可以尝试time.dep<-M.sub[,c(x-1,x)]
吗?
这对我有用。