inst/tinytest/test-ergm_blockdiagonal.R

data(fivenets)
suppressMessages(require(network))

set.seed(771)
fivenets <- lapply(fivenets, function(net) {
  
  net %v% "rand1" <- runif(network.size(net))
  net
    
})
  
net1 <- blockdiagonalize(fivenets)
net1 <- splitnetwork(net1, "block")
net2 <- blockdiagonalize(as_adjmat(fivenets)) # Regardless of whether it has attrs or not
net2 <- splitnetwork(net2, "block")

# Structure is preserved
expect_equal(as_adjmat(net1), as_adjmat(fivenets))
expect_equal(as_adjmat(fivenets), as_adjmat(net2))

# Attributes are preserved
expect_equal(
  lapply(net1, get.vertex.attribute, "rand1"),
  lapply(fivenets, get.vertex.attribute, "rand1")
)

data(fivenets)
net0 <- blockdiagonalize(fivenets)

ans0 <- ergmito(fivenets ~ edges + nodematch("female"))
suppressMessages(require(ergm))
suppressMessages(
  ans1 <- ergm(net0 ~ edges + nodematch("female"), constraints = ~ blockdiag("block"))
)

expect_equal(coef(ans0), coef(ans1), tol=.5)

ans0 <- ergmito(fivenets ~ edges + nodematch("female"))
suppressMessages(
  ans1 <- ergm_blockdiag(fivenets ~ edges + nodematch("female"))
)

expect_equal(coef(ans0), coef(ans1), tol=.5)
  

Try the ergmito package in your browser

Any scripts or data that you put into this service are public.

ergmito documentation built on July 9, 2023, 7:09 p.m.