WinBUGS inits:“初始值的数量不等于向量的长度”

时间:2013-05-16 17:52:55

标签: winbugs

我找不到我的BUGS模型的问题。模型语法是正确的,数据加载正常,但我在加载我的inits时出现以下错误消息:

初始值的数量不等于向量的长度

我的代码在下面提供,供您欣赏。

一切顺利!

  • 卡米拉

    model {
    
        for(w in 1: W){
        m[w] <- n[w]-y1[w]
        h[w] <- n[w]-y1[w]-y2[w]
        y1[w] ~ dbin(delta[w],n[w])
        y2[w] ~ dbin(theta[w],m[w])
        y3[w] ~ dbin(eta[w],h[w])
        y4[w] <- n[w]-y1[w]-y2[w]-y3[w]
        logit(delta[w]) <- mu1+theta1[a[w]]+phi1[p[w]]+psi1[c[w]]
        logit(theta[w]) <- mu2+theta2[a[w]]+phi2[p[w]]+psi2[c[w]]
        logit(eta[w]) <- mu3+theta3[a[w]]+phi3[p[w]]+psi3[c[w]]
    }
    
    mu1~ dnorm(0,1000)
    mu2~ dnorm(0,1000)
    mu3~ dnorm(0,1000)
    
    phi1mean[1] <- 0.0
    phi1prec[1] <- tauphi1*1.0E-6
    phi1mean[2] <- 0.0
    phi1prec[2] <- tauphi1*1.0E-6
    
    phi2mean[1] <- 0.0
    phi2prec[1] <- tauphi2*1.0E-6
    phi2mean[2] <- 0.0
    phi2prec[2] <- tauphi2*1.0E-6
    
    phi3mean[1] <- 0.0
    phi3prec[1] <- tauphi3*1.0E-6
    phi3mean[2] <- 0.0
    phi3prec[2] <- tauphi3*1.0E-6
    
    phi4mean[1] <- 0.0
    phi4prec[1] <- tauphi4*1.0E-6
    phi4mean[2] <- 0.0
    phi4prec[2] <- tauphi4*1.0E-6
    
    for (j in 3:JJ) {
        phi1mean[j] <- 2*phi1[j-1]-phi1[j-2]
        phi1prec[j] <- tauphi1
        phi2mean[j] <- 2*phi2[j-1]-phi2[j-2]
        phi2prec[j] <- tauphi2
        phi3mean[j] <- 2*phi3[j-1]-phi3[j-2]
        phi3prec[j] <- tauphi3
        phi4mean[j] <- 2*phi4[j-1]-phi4[j-2]
        phi4prec[j] <- tauphi4
    }
    
    for (j in 1:JJ) {
        phi1[j] ~ dnorm(phi1mean[j],phi1prec[j])
        phi2[j] ~ dnorm(phi2mean[j],phi2prec[j])
        phi3[j] ~ dnorm(phi3mean[j],phi3prec[j])
        phi4[j] ~ dnorm(phi4mean[j],phi4prec[j])
        phi1c[j] <- phi1[j]-mean(phi1[1:J])
        phi2c[j] <- phi2[j]-mean(phi2[1:J])
        phi3c[j] <- phi3[j]-mean(phi3[1:J])
        phi4c[j] <- phi4[j]-mean(phi4[1:J])
    }
    
    
    tauphi1 ~ dgamma(1.0E-1,1.0E-1)
    tauphi2 ~ dgamma(1.0E-1,1.0E-1)
    tauphi3 ~ dgamma(1.0E-1,1.0E-1)
    tauphi4 ~ dgamma(1.0E-1,1.0E-1)
    sigmaphi1 <- 1/sqrt(tauphi1)
    sigmaphi2 <- 1/sqrt(tauphi2)
    sigmaphi3 <- 1/sqrt(tauphi3)
    sigmaphi4 <- 1/sqrt(tauphi4)
    
    psi1mean[1] <- 0.0
    psi1prec[1] <- taupsi1*1.0E-6
    psi1mean[2] <- 0.0
    psi1prec[2] <- taupsi1*1.0E-6
    
    psi2mean[1] <- 0.0
    psi2prec[1] <- taupsi2*1.0E-6
    psi2mean[2] <- 0.0
    psi2prec[2] <- taupsi2*1.0E-6
    
    psi3mean[1] <- 0.0
    psi3prec[1] <- taupsi3*1.0E-6
    psi3mean[2] <- 0.0
    psi3prec[2] <- taupsi3*1.0E-6
    
    psi4mean[1] <- 0.0
    psi4prec[1] <- taupsi4*1.0E-6
    psi4mean[2] <- 0.0
    psi4prec[2] <- taupsi4*1.0E-6
    
    for (l in 3:LL) {
        psi1mean[l] <- 2*psi1[l-1]-psi1[l-2]
        psi1prec[l] <- taupsi1
        psi2mean[l] <- 2*psi2[l-1]-psi2[l-2]
        psi2prec[l] <- taupsi2
        psi3mean[l] <- 2*psi3[l-1]-psi3[l-2]
        psi3prec[l] <- taupsi3
        psi4mean[l] <- 2*psi4[l-1]-psi4[l-2]
        psi4prec[l] <- taupsi4
    }
    
    for (l in 1:LL) {
        psi1[l]  ~ dnorm(psi1mean[l],psi1prec[l])
        psi2[l]  ~ dnorm(psi2mean[l],psi2prec[l])
        psi3[l]  ~ dnorm(psi3mean[l],psi3prec[l])
        psi4[l]  ~ dnorm(psi4mean[l],psi4prec[l])
        psi1c[l] <- psi1[l]-mean(psi1[1:L])
        psi2c[l] <- psi2[l]-mean(psi2[1:L])
        psi3c[l] <- psi3[l]-mean(psi3[1:L])
        psi4c[l] <- psi4[l]-mean(psi4[1:L])
    }
    
    taupsi1 ~ dgamma(1.0E-1,1.0E-1)
    taupsi2 ~ dgamma(1.0E-1,1.0E-1)
    taupsi3 ~ dgamma(1.0E-1,1.0E-1)
    taupsi4 ~ dgamma(1.0E-1,1.0E-1)
    sigmapsi1 <- 1/sqrt(taupsi1)
    sigmapsi2 <- 1/sqrt(taupsi2)
    sigmapsi3 <- 1/sqrt(taupsi3)
    sigmapsi4 <- 1/sqrt(taupsi4)
    
    theta1mean[1] <- 0.0
    theta1prec[1] <- tautheta1*1.0E-6
    theta1mean[2] <- 0.0
    theta1prec[2] <- tautheta1*1.0E-6
    
    theta2mean[1] <- 0.0
    theta2prec[1] <- tautheta2*1.0E-6
    theta2mean[2] <- 0.0
    theta2prec[2] <- tautheta2*1.0E-6
    
    theta3mean[1] <- 0.0
    theta3prec[1] <- tautheta3*1.0E-6
    theta3mean[2] <- 0.0
    theta3prec[2] <- tautheta3*1.0E-6
    
    theta4mean[1] <- 0.0
    theta4prec[1] <- tautheta4*1.0E-6
    theta4mean[2] <- 0.0
    theta4prec[2] <- tautheta4*1.0E-6
    
    for (i in 3:I) {
        theta1mean[i] <- 2*theta1[i-1]-theta1[i-2]
        theta1prec[i] <- tautheta1
        theta2mean[i] <- 2*theta2[i-1]-theta2[i-2]
        theta2prec[i] <- tautheta2
        theta3mean[i] <- 2*theta3[i-1]-theta3[i-2]
        theta3prec[i] <- tautheta3
        theta4mean[i] <- 2*theta4[i-1]-theta4[i-2]
        theta4prec[i] <- tautheta4
    }
    
    for (i in 1:I) {
        theta1[i] ~ dnorm(theta1mean[i],theta1prec[i])
        theta2[i] ~ dnorm(theta2mean[i],theta2prec[i])
        theta3[i] ~ dnorm(theta3mean[i],theta3prec[i])
        theta4[i] ~ dnorm(theta4mean[i],theta4prec[i])
    }
    
    tautheta1 ~ dgamma(1.0E-1,1.0E-1)
    tautheta2 ~ dgamma(1.0E-1,1.0E-1)
    tautheta3 ~ dgamma(1.0E-1,1.0E-1)
    tautheta4 ~ dgamma(1.0E-1,1.0E-1)
    sigmatheta1 <- 1/sqrt(tautheta1)
    sigmatheta2 <- 1/sqrt(tautheta2)
    sigmatheta3 <- 1/sqrt(tautheta3)
    sigmatheta4 <- 1/sqrt(tautheta4)
    
        for (i in 1:I) {
        ivec1[i] <- i-(I+1)/2
        aivec1[i] <- ivec1[i]*theta1[i]
        theta1c[i] <- theta1[i]-ivec1[i]*sum(aivec1[])/(I*(I+1)*(I-1)/12)
        ivec2[i] <- i-(I+1)/2
        aivec2[i] <- ivec2[i]*theta2[i]
        theta2c[i] <- theta2[i]-ivec2[i]*sum(aivec2[])/(I*(I+1)*(I-1)/12)
        ivec3[i] <- i-(I+1)/2
        aivec3[i] <- ivec3[i]*theta3[i]
        theta3c[i] <- theta3[i]-ivec3[i]*sum(aivec3[])/(I*(I+1)*(I-1)/12)
        ivec4[i] <- i-(I+1)/2
        aivec4[i] <- ivec4[i]*theta4[i]
        theta4c[i] <- theta4[i]-ivec4[i]*sum(aivec4[])/(I*(I+1)*(I-1)/12)
    }
    
    for (i in 1:I) {
        for (j in 1:JJ) {
            deltapred[i,j]   <- exp(mu1+theta1[i]+phi1[j]+psi1[I+j-i])
            thetapred[i,j]   <- exp(mu2+theta2[i]+phi2[j]+psi2[I+j-i])
            etapred[i,j]   <- exp(mu3+theta3[i]+phi3[j]+psi3[I+j-i])
            p1[i,j]    <- deltapred[i,j]
            p2[i,j]    <- thetapred[i,j]*(1-deltapred[i,j])
            p3[i,j]    <- etapred[i,j]*(1-deltapred[i,j])*(1-thetapred[i,j])
            p4[i,j]    <- (1-deltapred[i,j])*(1-thetapred[i,j]-etapred[i,j]+(etapred[i,j]*thetapred[i,j]))
        }
    }
        }
    
    
    # Data
    
    list(
    y1=c(1538727,1444672,1206999,1002960,744597,390301,1640130,1472255,1383947,1109395,984775,697701,1769569,1573498,1489025,1351284,1111397,935166,1747764,1790841,1626852,1407388,1284583,995236,1676555,1787181,1655400,1527122,1421772,1309989,1561922,1643467,1598855,1570645,1495999,1319439,1456258,1561892,1567872,1555237,1551579,1532222,1243436,1387943,1436659,1511134,1549578,1539580),
    y2=c(2634569,3031916,3138776,2875868,2495888,1886174,2148776,2567507,2747428,2696199,2593985,2138303,1662296,2224336,2489723,2698322,2655746,2450716,1304387,1734318,2180203,2396749,2629088,2555934,1087351,1380119,1616309,2109287,2408800,2369855,821642,1041702,1221283,1661647,2098345,2426842,708327,873092,952245,1237084,1628334,2123709,549763,666699,774205,981393,1243888,1538431),
    y3=c(1245931,1664176,1659375,2313647,3850196,4254634,825634,1293382,1454776,1736181,2596719,3655532,554953,901957,1186747,1490664,2083400,2738988,335824,630232,847486,1239538,1702256,2296941,218213,373786,555286,907876,1397221,2005940,143202,237344,344229,594993,1012777,1510283,121187,151070,219731,351040,650930,1157146,87211,120279,140551,226530,393887,733699),
    n=c(5862309,6673625,6534802,6942747,8329067,8152696,5049199,5913474,6268113,6253757,7298375,8260640,4319559,5245545,5840408,6306245,6785242,7492958,3588778,4553684,5259609,5813653,6517271,7001560,3105173,3797508,4271831,5180290,6086716,7002991,2591140,3063506,3428373,4305319,5326889,6217360,2329398,2661972,2886111,3418403,4327922,5565798,1906676,2224544,2444586,2864892,3473404,4362648),
    a=c(1,1,1,1,1,1,2,2,2,2,2,2,3,3,3,3,3,3,4,4,4,4,4,4,5,5,5,5,5,5,6,6,6,6,6,6,7,7,7,7,7,7,8,8,8,8,8,8),
    p=c(1,2,3,4,5,6,1,2,3,4,5,6,1,2,3,4,5,6,1,2,3,4,5,6,1,2,3,4,5,6,1,2,3,4,5,6,1,2,3,4,5,6,1,2,3,4,5,6),
    c=c(8,9,10,11,12,13,7,8,9,10,11,12,6,7,8,9,10,11,5,6,7,8,9,10,4,5,6,7,8,9,3,4,5,6,7,8,2,3,4,5,6,7,1,2,3,4,5,6),
    W=48,
    I=8,
    J=6,
    JJ=8,
    L=13,
    LL=15
    )
    
    # Inits
    list(
    tauphi1=1,
    tauphi2=1,
    tauphi3=1,
    tauphi4=1,
    taupsi1=1,
    taupsi2=1,
    taupsi3=1,
    taupsi4=1,
    tautheta1=1,
    tautheta2=1,
    tautheta3=1,
    tautheta4=1,
    mu1=0,
    mu2=0,
    mu3=0,
    theta1=c(0,0,0,0,0,0,0,0),
    theta2=c(0,0,0,0,0,0,0,0),
    theta3=c(0,0,0,0,0,0,0,0),
    theta4=c(0,0,0,0,0,0,0,0),
    phi1=c(0,0,0,0,0,0),
    phi2=c(0,0,0,0,0,0),
    phi3=c(0,0,0,0,0,0),
    phi4=c(0,0,0,0,0,0),
    psi1=c(0,0,0,0,0,0,0,0,0,0,0,0,0),
    psi2=c(0,0,0,0,0,0,0,0,0,0,0,0,0),
    psi3=c(0,0,0,0,0,0,0,0,0,0,0,0,0),
    psi4=c(0,0,0,0,0,0,0,0,0,0,0,0,0)
    )
    

1 个答案:

答案 0 :(得分:1)

出现错误消息时,光标应放在初始值列表中的错误向量之后。在您的情况下,这是phi1,因为您提供了6个初始值,但在模型代码中,phi1 [j]定义为j = 1到JJ = 8.