Title: | Utility Functions of the Potts Models |
---|---|
Description: | There are three sets of functions. The first produces basic properties of a graph and generates samples from multinomial distributions to facilitate the simulation functions (they maybe used for other purposes as well). The second provides various simulation functions for a Potts model in Potts, R. B. (1952) <doi:10.1017/S0305004100027419>. The third currently includes only one function which computes the normalizing constant of a Potts model based on simulation results. |
Authors: | Dai Feng [aut, cre], Luke Tierney [ctb] |
Maintainer: | Dai Feng <[email protected]> |
License: | GPL-2 |
Version: | 0.3-3.1 |
Built: | 2024-12-12 06:45:12 UTC |
Source: | CRAN |
Generate random samples from a Potts model by Gibbs Sampling that takes advantage of conditional independence.
BlocksGibbs(n, nvertex, ncolor, neighbors, blocks, weights=1, spatialMat=NULL, beta)
BlocksGibbs(n, nvertex, ncolor, neighbors, blocks, weights=1, spatialMat=NULL, beta)
n |
number of samples. |
nvertex |
number of vertices in a graph. |
ncolor |
number of colors each vertex can take. |
neighbors |
a matrix of all neighbors in a graph, one row per vertex. |
blocks |
a list of blocks of vertices in a graph. |
weights |
weights between neighbors. One for each corresponding
neighbor in |
spatialMat |
the matrix that describes the relationship among
vertices in neighbor. The default value is |
beta |
the parameter inverse temperature of the Potts model. |
We use the Gibbs algorithm that takes advantage of conditional independence to speed up the generation of random samples from a Potts model. The idea is that if we can divide variables that need to be updated into different blocks and given the variables in other blocks, all the variables within the same block are conditionally independent, then we can update all blocks iteratively with the variables within the same block being updated simultaneously.
The spatialMat
is the argument used to specify the
relationship among vertices in neighbor. See
rPotts1
for more information on the Potts
model and spatialMat
.
The output is a nvertex
by n
matrix with
the kth column being the kth sample.
Dai Feng (2008) Bayesian Hidden Markov Normal Mixture Models with Application to MRI Tissue Classification Ph. D. Dissertation, The University of Iowa
#Example 1: Generate 100 samples from a repulsion Potts model with the # neighborhood structure corresponding to a first-order # Markov random field defined on a 3*3 2D graph. # The number of colors is 3 and beta=0.1,a_1=2,a_2=1,a_3=0. # All weights are equal to 1. neighbors <- getNeighbors(mask=matrix(1, 3, 3), neiStruc=c(2,2,0,0)) blocks <- getBlocks(mask=matrix(1, 3, 3), nblock=2) spatialMat <- matrix(c(2,1,0, 1,2,1,0,1,2), ncol=3) BlocksGibbs(n=100, nvertex=9, ncolor=3, neighbors=neighbors, blocks=blocks, spatialMat=spatialMat, beta=0.1)
#Example 1: Generate 100 samples from a repulsion Potts model with the # neighborhood structure corresponding to a first-order # Markov random field defined on a 3*3 2D graph. # The number of colors is 3 and beta=0.1,a_1=2,a_2=1,a_3=0. # All weights are equal to 1. neighbors <- getNeighbors(mask=matrix(1, 3, 3), neiStruc=c(2,2,0,0)) blocks <- getBlocks(mask=matrix(1, 3, 3), nblock=2) spatialMat <- matrix(c(2,1,0, 1,2,1,0,1,2), ncol=3) BlocksGibbs(n=100, nvertex=9, ncolor=3, neighbors=neighbors, blocks=blocks, spatialMat=spatialMat, beta=0.1)
Obtain blocks of vertices of a 1D, 2D, or 3D graph, in order to use the conditional independence to speed up the simulation (checkerboard idea).
getBlocks(mask, nblock)
getBlocks(mask, nblock)
mask |
a vector, matrix, or 3D array specifying vertices of a graph. Vertices of value 1 are within the graph and 0 are not. |
nblock |
a scalar specifying the number of blocks. For
a 2D graph |
The vertices within each block are mutually independent given the vertices in other blocks. Some blocks could be empty.
A list with the number of components equal to nblock
. Each
component consists of vertices within the same block.
Darren J. Wilkinson Parallel Bayesian Computation Handbook of Parallel Computing and Statistics 481-512 Marcel Dekker/CRC Press 2005
#Example 1: split a line into 2 blocks getBlocks(mask=c(1,1,1,1,0,0,1,1,0), nblock=2) #Example 2: split a 4*4 2D graph into 4 blocks in order # to use the checkerboard idea for a neighborhood structure # corresponding to the second-order Markov random field. getBlocks(mask=matrix(1, nrow=4, ncol=4), nblock=4) #Example 3: split a 3*3*3 3D graph into 8 blocks # in order to use the checkerboard idea for a neighborhood # structure based on the 18 neighbors definition, where the # neighbors of a vertex comprise its available # adjacencies sharing the same edges or faces. mask <- array(1, dim=rep(3,3)) getBlocks(mask, nblock=8)
#Example 1: split a line into 2 blocks getBlocks(mask=c(1,1,1,1,0,0,1,1,0), nblock=2) #Example 2: split a 4*4 2D graph into 4 blocks in order # to use the checkerboard idea for a neighborhood structure # corresponding to the second-order Markov random field. getBlocks(mask=matrix(1, nrow=4, ncol=4), nblock=4) #Example 3: split a 3*3*3 3D graph into 8 blocks # in order to use the checkerboard idea for a neighborhood # structure based on the 18 neighbors definition, where the # neighbors of a vertex comprise its available # adjacencies sharing the same edges or faces. mask <- array(1, dim=rep(3,3)) getBlocks(mask, nblock=8)
Using recursive method to generate all possible configurations of a graph.
getConfs(nvertex, ncolor)
getConfs(nvertex, ncolor)
nvertex |
number of vertices in a graph. |
ncolor |
number of colors each vertex can take. |
Suppose there are n vertices and each can take values from
.
This function generates all possible configurations.
For example, if there are two vertices and each can be either 1 or 2,
then the possible configurations are (1,1), (1,2), (2,1) and (2,2).
A matrix of all possible configurations. Each column corresponds to one configuration.
#Example 1: There are two vertices and each is either of # color 1 or 2. getConfs(2,2)
#Example 1: There are two vertices and each is either of # color 1 or 2. getConfs(2,2)
Obtain edges of a 1D, 2D, or 3D graph based on the neighborhood structure.
getEdges(mask, neiStruc)
getEdges(mask, neiStruc)
mask |
a vector, matrix, or 3D array specifying vertices of a graph. Vertices of value 1 are within the graph and 0 are not. |
neiStruc |
a scalar, vector of four components, or
|
There could be more than one way to define the same 3D neighborhood structure for a graph (see Example 4 for illustration).
A matrix of two columns with one edge per row. The edges connecting
vertices and their corresponding first neighbors are listed first, and
then those corresponding to the second neighbors, and so on and so
forth. The order of neighbors is the same as in getNeighbors
.
Gerhard Winkler (1995) Image Analysis, Random Fields and Dynamic Monte Carlo Methods Springer-Verlag
Dai Feng (2008) Bayesian Hidden Markov Normal Mixture Models with Application to MRI Tissue Classification Ph. D. Dissertation, The University of Iowa
#Example 1: get all edges of a 1D graph. mask <- c(0,0,rep(1,4),0,1,1,0,0) getEdges(mask, neiStruc=2) #Example 2: get all edges of a 2D graph based on neighborhood structure # corresponding to the first-order Markov random field. mask <- matrix(1 ,nrow=2, ncol=3) getEdges(mask, neiStruc=c(2,2,0,0)) #Example 3: get all edges of a 2D graph based on neighborhood structure # corresponding to the second-order Markov random field. mask <- matrix(1 ,nrow=3, ncol=3) getEdges(mask, neiStruc=c(2,2,2,2)) #Example 4: get all edges of a 3D graph based on 6 neighbors structure # where the neighbors of a vertex comprise its available # N,S,E,W, upper and lower adjacencies. To achieve it, there # are several ways, including the two below. mask <- array(1, dim=rep(3,3)) n61 <- matrix(c(2,2,0,0, 0,2,0,0, 0,0,0,0), nrow=3, byrow=TRUE) n62 <- matrix(c(2,0,0,0, 0,2,0,0, 2,0,0,0), nrow=3, byrow=TRUE) e1 <- getEdges(mask, neiStruc=n61) e2 <- getEdges(mask, neiStruc=n62) e1 <- e1[order(e1[,1], e1[,2]),] e2 <- e2[order(e2[,1], e2[,2]),] all(e1==e2) #Example 5: get all edges of a 3D graph based on 18 neighbors structure # where the neighbors of a vertex comprise its available # adjacencies sharing the same edges or faces. # To achieve it, there are several ways, including the one below. n18 <- matrix(c(2,2,2,2, 0,2,2,2, 0,0,2,2), nrow=3, byrow=TRUE) mask <- array(1, dim=rep(3,3)) getEdges(mask, neiStruc=n18)
#Example 1: get all edges of a 1D graph. mask <- c(0,0,rep(1,4),0,1,1,0,0) getEdges(mask, neiStruc=2) #Example 2: get all edges of a 2D graph based on neighborhood structure # corresponding to the first-order Markov random field. mask <- matrix(1 ,nrow=2, ncol=3) getEdges(mask, neiStruc=c(2,2,0,0)) #Example 3: get all edges of a 2D graph based on neighborhood structure # corresponding to the second-order Markov random field. mask <- matrix(1 ,nrow=3, ncol=3) getEdges(mask, neiStruc=c(2,2,2,2)) #Example 4: get all edges of a 3D graph based on 6 neighbors structure # where the neighbors of a vertex comprise its available # N,S,E,W, upper and lower adjacencies. To achieve it, there # are several ways, including the two below. mask <- array(1, dim=rep(3,3)) n61 <- matrix(c(2,2,0,0, 0,2,0,0, 0,0,0,0), nrow=3, byrow=TRUE) n62 <- matrix(c(2,0,0,0, 0,2,0,0, 2,0,0,0), nrow=3, byrow=TRUE) e1 <- getEdges(mask, neiStruc=n61) e2 <- getEdges(mask, neiStruc=n62) e1 <- e1[order(e1[,1], e1[,2]),] e2 <- e2[order(e2[,1], e2[,2]),] all(e1==e2) #Example 5: get all edges of a 3D graph based on 18 neighbors structure # where the neighbors of a vertex comprise its available # adjacencies sharing the same edges or faces. # To achieve it, there are several ways, including the one below. n18 <- matrix(c(2,2,2,2, 0,2,2,2, 0,0,2,2), nrow=3, byrow=TRUE) mask <- array(1, dim=rep(3,3)) getEdges(mask, neiStruc=n18)
Use the thermodynamic integration approach to calculate the normalizing constant of a Simple Potts Model.
getNC(beta, subbetas, nvertex, ncolor, edges, neighbors=NULL, blocks=NULL, algorithm=c("SwendsenWang", "Gibbs", "Wolff"), n, burn)
getNC(beta, subbetas, nvertex, ncolor, edges, neighbors=NULL, blocks=NULL, algorithm=c("SwendsenWang", "Gibbs", "Wolff"), n, burn)
beta |
the inverse temperature parameter of the Potts model. |
subbetas |
vector of betas used for the integration. |
nvertex |
number of vertices in a graph. |
ncolor |
number of colors each vertex can take. |
edges |
all edges in a graph. |
neighbors |
all neighbors in a graph. The default is
|
blocks |
the blocks of vertices of a graph. The default is
|
algorithm |
a character string specifying the algorithm used to generate samples. It must be one of "SwendsenWang", "Gibbs", or "Wolff" and may be abbreviated. The default is "SwendsenWang". |
n |
number of iterations. |
burn |
number of burn-in. |
Use the thermodynamic integration approach to calculate the normalizing
constant from a simple Potts model. See
rPotts1
for more information on the simple Potts model.
By the thermodynamic integration method,
where N is the total number of vertices (nvertex
), k is the
number of colors (ncolor
), and
.
Calculate
for
subbetas
based on samples,
and then compute the integral by numerical integration.
The corresponding normalizing constant.
Peter J. Green and Sylvia Richardson (2002) Hidden Markov Models and Disease Mapping Journal of the American Statistical Association vol. 97, no. 460, 1055-1070
## Not run: #Example 1: Calculate the normalizing constant of a simple Potts model # with the neighborhood structure corresponding to a # first-order Markov random field defined on a # 3*3 2D graph. The number of colors is 2 and beta=2. # Use 11 subbetas evenly distributed between 0 and 2. # The sampling algorithm is Swendsen-Wang with 10000 # iterations and 1000 burn-in. edges <- getEdges(mask=matrix(1,3,3), neiStruc=c(2,2,0,0)) getNC(beta=2, subbetas=seq(0,2,by=0.2), nvertex=3*3, ncolor=2, edges, algorithm="S", n=10000, burn=1000) ## End(Not run)
## Not run: #Example 1: Calculate the normalizing constant of a simple Potts model # with the neighborhood structure corresponding to a # first-order Markov random field defined on a # 3*3 2D graph. The number of colors is 2 and beta=2. # Use 11 subbetas evenly distributed between 0 and 2. # The sampling algorithm is Swendsen-Wang with 10000 # iterations and 1000 burn-in. edges <- getEdges(mask=matrix(1,3,3), neiStruc=c(2,2,0,0)) getNC(beta=2, subbetas=seq(0,2,by=0.2), nvertex=3*3, ncolor=2, edges, algorithm="S", n=10000, burn=1000) ## End(Not run)
Obtain neighbors of vertices of a 1D, 2D, or 3D graph.
getNeighbors(mask, neiStruc)
getNeighbors(mask, neiStruc)
mask |
a vector, matrix, or 3D array specifying vertices within a graph. Vertices of value 1 are within the graph and 0 are not. |
neiStruc |
a scalar, vector of four components, or |
There could be more than one way to define the same 3D neighborhood structure for a graph (see Example 3 for illustration).
A matrix with each row giving the neighbors of a vertex. The number of the rows is equal to the number of vertices within the graph and the number or columns is the number of neighbors of each vertex.
For a 1D graph, if each vertex has two neighbors,
The first column are the neighbors on the left-hand side of
corresponding vertices and the second column the right-hand side.
For the vertices on boundaries, missing neighbors are represented by
the number of vertices within a graph plus 1.
When neiStruc
is bigger than 2, The first two columns
are the same as when neiStruc
is equal to 2; the third column
are the neighbors on the left-hand side of the vertices on the first column;
the forth column are the neighbors on the right-hand side of the vertices
on the second column, and so on and so forth. And again for the
vertices on boundaries, their missing neighbors are represented by
the number of vertices within a graph plus 1.
For a 2D graph, the index to vertices is column-wised. For each vertex, the order of neighbors are as follows. First are those on the vertical direction, second the horizontal direction, third the NW to SE diagonal direction, and forth the SW to NE diagonal direction. For each direction, the neighbors of every vertex are arranged in the same way as in a 1D graph.
For a 3D graph, the index to vertices is that the leftmost subscript of the array moves the fastest. For each vertex, the neighbors from the 1-2 perspective appear first and then the 1-3 perspective and finally the 2-3 perspective. For each perspective, the neighbors are arranged in the same way as in a 2D graph.
Gerhard Winkler (1995) Image Analysis, Random Fields and Dynamic Monte Carlo Methods Springer-Verlag
Dai Feng (2008) Bayesian Hidden Markov Normal Mixture Models with Application to MRI Tissue Classification Ph. D. Dissertation, The University of Iowa
#Example 1: get all neighbors of a 1D graph. mask <- c(0,0,rep(1,4),0,1,1,0,0,1,1,1) getNeighbors(mask, neiStruc=2) #Example 2: get all neighbors of a 2D graph based on neighborhood structure # corresponding to the second-order Markov random field. mask <- matrix(1, nrow=2, ncol=3) getNeighbors(mask, neiStruc=c(2,2,2,2)) #Example 3: get all neighbors of a 3D graph based on 6 neighbors structure # where the neighbors of a vertex comprise its available # N,S,E,W, upper and lower adjacencies. To achieve it, there # are several ways, including the two below. mask <- array(1, dim=rep(3,3)) n61 <- matrix(c(2,2,0,0, 0,2,0,0, 0,0,0,0), nrow=3, byrow=TRUE) n62 <- matrix(c(2,0,0,0, 0,2,0,0, 2,0,0,0), nrow=3, byrow=TRUE) n1 <- getNeighbors(mask, neiStruc=n61) n2 <- getNeighbors(mask, neiStruc=n62) n1 <- apply(n1, 1, sort) n2 <- apply(n2, 1, sort) all(n1==n2) #Example 4: get all neighbors of a 3D graph based on 18 neighbors structure # where the neighbors of a vertex comprise its available # adjacencies sharing the same edges or faces. # To achieve it, there are several ways, including the one below. n18 <- matrix(c(2,2,2,2, 0,2,2,2, 0,0,2,2), nrow=3, byrow=TRUE) mask <- array(1, dim=rep(3,3)) getNeighbors(mask, neiStruc=n18)
#Example 1: get all neighbors of a 1D graph. mask <- c(0,0,rep(1,4),0,1,1,0,0,1,1,1) getNeighbors(mask, neiStruc=2) #Example 2: get all neighbors of a 2D graph based on neighborhood structure # corresponding to the second-order Markov random field. mask <- matrix(1, nrow=2, ncol=3) getNeighbors(mask, neiStruc=c(2,2,2,2)) #Example 3: get all neighbors of a 3D graph based on 6 neighbors structure # where the neighbors of a vertex comprise its available # N,S,E,W, upper and lower adjacencies. To achieve it, there # are several ways, including the two below. mask <- array(1, dim=rep(3,3)) n61 <- matrix(c(2,2,0,0, 0,2,0,0, 0,0,0,0), nrow=3, byrow=TRUE) n62 <- matrix(c(2,0,0,0, 0,2,0,0, 2,0,0,0), nrow=3, byrow=TRUE) n1 <- getNeighbors(mask, neiStruc=n61) n2 <- getNeighbors(mask, neiStruc=n62) n1 <- apply(n1, 1, sort) n2 <- apply(n2, 1, sort) all(n1==n2) #Example 4: get all neighbors of a 3D graph based on 18 neighbors structure # where the neighbors of a vertex comprise its available # adjacencies sharing the same edges or faces. # To achieve it, there are several ways, including the one below. n18 <- matrix(c(2,2,2,2, 0,2,2,2, 0,0,2,2), nrow=3, byrow=TRUE) mask <- array(1, dim=rep(3,3)) getNeighbors(mask, neiStruc=n18)
Obtain patches of a graph by Rem's algorithm.
getPatches(bonds, nvertex)
getPatches(bonds, nvertex)
bonds |
a matrix of bonds in a graph, with one bond per row. |
nvertex |
number of vertices in a graph. |
Given all bonds and the number of vertices in a graph, this function provides all patches.
A list comprises all patches in a graph. Each component of the list consists of vertices within one patch.
Edsger W. Dijkstra (1976) A Discipline of Programming Englewood Cliffs, New Jersey : Prentice-Hall, Inc
#Example 1: Find patches of a 3*3 2D graph with 6 bonds. bonds <- matrix(c(1,2,2,5,5,6,3,6,5,8,7,8), ncol=2, byrow=TRUE) getPatches(bonds, 9)
#Example 1: Find patches of a 3*3 2D graph with 6 bonds. bonds <- matrix(c(1,2,2,5,5,6,3,6,5,8,7,8), ncol=2, byrow=TRUE) getPatches(bonds, 9)
Obtain weights of edges of a 1D, 2D, or 3D graph based on the neighborhood structure.
getWeights(mask, neiStruc, format=1)
getWeights(mask, neiStruc, format=1)
mask |
a vector, matrix, or 3D array specifying vertices within a graph. Vertices of value 1 are within the graph and 0 are not. |
neiStruc |
a scalar, vector of four components,
or |
format |
If it is 1, then the output is a vector of weights,
one for two vertices in the corresponding output from
|
The weights are equal to the reciprocals of the distance between neighboring vertices.
A vector of weights, one component corresponding to an edge of a graph. Or a matrix of weights, one component corresponding to two vertices in neighbor.
#Example 1: get all weights of a 2D graph based on neighborhood structure # corresponding to the first-order Markov random field. mask <- matrix(1 ,nrow=2, ncol=3) getWeights(mask, neiStruc=c(2,2,0,0)) #Example 2: get all weights of a 2D graph based on neighborhood structure # corresponding to the second-order Markov random field. # Put the weights in a matrix form corresponding to # neighbors of vertices. mask <- matrix(1 ,nrow=3, ncol=3) getWeights(mask, neiStruc=c(2,2,2,2), format=2) #Example 3: get all weights of a 3D graph based on 6 neighbors structure # where the neighbors of a vertex comprise its available # N,S,E,W, upper and lower adjacencies. mask <- array(1, dim=rep(3,3)) n61 <- matrix(c(2,2,0,0, 0,2,0,0, 0,0,0,0), nrow=3, byrow=TRUE) getWeights(mask, neiStruc=n61)
#Example 1: get all weights of a 2D graph based on neighborhood structure # corresponding to the first-order Markov random field. mask <- matrix(1 ,nrow=2, ncol=3) getWeights(mask, neiStruc=c(2,2,0,0)) #Example 2: get all weights of a 2D graph based on neighborhood structure # corresponding to the second-order Markov random field. # Put the weights in a matrix form corresponding to # neighbors of vertices. mask <- matrix(1 ,nrow=3, ncol=3) getWeights(mask, neiStruc=c(2,2,2,2), format=2) #Example 3: get all weights of a 3D graph based on 6 neighbors structure # where the neighbors of a vertex comprise its available # N,S,E,W, upper and lower adjacencies. mask <- array(1, dim=rep(3,3)) n61 <- matrix(c(2,2,0,0, 0,2,0,0, 0,0,0,0), nrow=3, byrow=TRUE) getWeights(mask, neiStruc=n61)
Generate one random sample from a Potts model with external field by Gibbs Sampling that takes advantage of conditional independence, or the partial decoupling method.
rPotts1(nvertex, ncolor, neighbors, blocks, edges=NULL, weights=1, spatialMat=NULL, beta, external, colors, algorithm=c("Gibbs", "PartialDecoupling"))
rPotts1(nvertex, ncolor, neighbors, blocks, edges=NULL, weights=1, spatialMat=NULL, beta, external, colors, algorithm=c("Gibbs", "PartialDecoupling"))
nvertex |
number of vertices in a graph. |
ncolor |
number of colors each vertex can take. |
neighbors |
all neighbors in a graph. It is not required when using the partial decoupling method. |
blocks |
the blocks of vertices in a graph. It is not required when using the partial decoupling method. |
edges |
all edges in a graph. The default value is |
weights |
weights between neighbors or |
spatialMat |
a matrix that describes the relationship among
vertices in neighbor. It is not required when using the partial decoupling method. The default value is |
beta |
the parameter inverse temperature of the Potts model. |
external |
a matrix giving values of external field. The number
of rows equal to |
colors |
the current colors of vertices. |
algorithm |
a character string specifying the algorithm used to generate samples. It must be either "Gibbs", or "PartialDecoupling", and may be abbreviated. The default is "Gibbs". |
This function generates random samples from a Potts model as follows:
where is a normalizing constant
and
indicates neighboring vertices. The parameter
is called the
"inverse temperature", which determines the level of spatial homogeneity between
neighboring vertices in the graph. We assume
.
The set
comprises the indices to the colors of all vertices. Function
determines the relationship among vertices
in neighbor. Parameter
is the weight between vertex
and
. The term
is called the "external field".
For the simple, the compound, and the simple repulsion Potts
models,
the external field is equal to 0.
For the simple and the compound Potts model
.
Parameters
are all equal for the simple Potts model but
not so for the compound model.
For the repulsion Potts model if
;
if
;
otherwise.
The argument spatialMat
is used to specify the
relationship among vertices in neighbor. The default value is
NULL
corresponding to the simple or the compound Potts
model. The component at the th row and
th column
defining the relationship when the color of a vertex is
and the
color of its neighbors is
.
Besides the default setup, for the simple and the compound Potts models
spatailMat
could be an identity matrix also. For
the repulsion Potts model, it is
Other relationships among neighboring vertices can be specified through it as well.
Gibbs sampling can be used to generate samples from all
kinds of Potts models. We use the method that takes advantage of
conditional independence to speed up the simulation. See
BlocksGibbs
for details.
The partial decoupling method could be used to generate samples
from the simple Potts model plus the external field.
The s are specified through the argument
weights
.
The output is a vector with the kth component being the new color of vertex k.
Dai Feng (2008) Bayesian Hidden Markov Normal Mixture Models with Application to MRI Tissue Classification Ph. D. Dissertation, The University of Iowa
David M. Higdon (1998) Auxiliary variable methods for Markov Chain Monte Carlo with applications Journal of the American Statistical Association vol. 93 585-595
## Not run: neighbors <- getNeighbors(matrix(1, 16, 16), c(2,2,0,0)) blocks <- getBlocks(matrix(1, 16, 16), 2) spatialMat <- matrix(c(2, 0, -1, 0, 2, 0, -1, 0, 2), ncol=3) mu <- c(22, 70 ,102) sigma <- c(17, 16, 19) count <- c(40, 140, 76) y <- unlist(lapply(1:3, function(i) rnorm(count[i], mu[i], sigma[i]))) external <- do.call(cbind, lapply(1:3, function(i) dnorm(y, mu[i],sigma[i]))) current.colors <- rep(1:3, count) rPotts1(nvertex=16^2, ncolor=3, neighbors=neighbors, blocks=blocks, spatialMat=spatialMat, beta=0.3, external=external, colors=current.colors, algorithm="G") edges <- getEdges(matrix(1, 16, 16), c(2,2,0,0)) rPotts1(nvertex=16^2, ncolor=3, edges=edges, beta=0.3, external=external, colors=current.colors, algorithm="P") ## End(Not run)
## Not run: neighbors <- getNeighbors(matrix(1, 16, 16), c(2,2,0,0)) blocks <- getBlocks(matrix(1, 16, 16), 2) spatialMat <- matrix(c(2, 0, -1, 0, 2, 0, -1, 0, 2), ncol=3) mu <- c(22, 70 ,102) sigma <- c(17, 16, 19) count <- c(40, 140, 76) y <- unlist(lapply(1:3, function(i) rnorm(count[i], mu[i], sigma[i]))) external <- do.call(cbind, lapply(1:3, function(i) dnorm(y, mu[i],sigma[i]))) current.colors <- rep(1:3, count) rPotts1(nvertex=16^2, ncolor=3, neighbors=neighbors, blocks=blocks, spatialMat=spatialMat, beta=0.3, external=external, colors=current.colors, algorithm="G") edges <- getEdges(matrix(1, 16, 16), c(2,2,0,0)) rPotts1(nvertex=16^2, ncolor=3, edges=edges, beta=0.3, external=external, colors=current.colors, algorithm="P") ## End(Not run)
Generate random samples from a compound Potts model using the Swendsen-Wang algorithm.
SW(n, nvertex, ncolor, edges, weights, beta)
SW(n, nvertex, ncolor, edges, weights, beta)
n |
number of samples. |
nvertex |
number of vertices of a graph. |
ncolor |
number of colors each vertex can take. |
edges |
edges of a graph. |
weights |
weights of edges. One for each corresponding component in
|
beta |
the parameter inverse temperature of the Potts model. |
We use the Swendsen-Wang algorithm to generate random samples from a
compound Potts model. See rPotts1
for more
information on the compound Potts model.
The output is a nvertex
by n
matrix with
the kth column being the kth sample.
Robert H. Swendsen and Jian-Sheng Wang (1987) Nonuniversal Critical Dynamics in Monte Carlo Simulations Physical Review Letters vol. 58, no. 2, 86-88
Dai Feng (2008) Bayesian Hidden Markov Normal Mixture Models with Application to MRI Tissue Classification Ph. D. Dissertation, The University of Iowa
#Example 1: Generate 100 samples from a Potts model with the # neighborhood structure corresponding to a # second-order Markov random field defined on a # 3*3 2D graph. The number of colors is 2. # beta=0.1. All weights are equal to 1. edges <- getEdges(mask=matrix(1, 2, 2), neiStruc=rep(2,4)) set.seed(100) SW(n=500, nvertex=4, ncolor=2, edges, beta=0.8)
#Example 1: Generate 100 samples from a Potts model with the # neighborhood structure corresponding to a # second-order Markov random field defined on a # 3*3 2D graph. The number of colors is 2. # beta=0.1. All weights are equal to 1. edges <- getEdges(mask=matrix(1, 2, 2), neiStruc=rep(2,4)) set.seed(100) SW(n=500, nvertex=4, ncolor=2, edges, beta=0.8)
Generate random samples from a compound Potts model using the Wolff Algorithm.
Wolff(n, nvertex, ncolor, neighbors, weights, beta)
Wolff(n, nvertex, ncolor, neighbors, weights, beta)
n |
number of samples. |
nvertex |
number of vertices of a graph. |
ncolor |
number of colors each vertex can take. |
neighbors |
neighbors of a graph. |
weights |
weights between neighbors. One for each corresponding
component in |
beta |
the parameter inverse temperature of the Potts model. |
We use the Wolff algorithm to generate random samples from a compound
Potts model. See rPotts1
for more
information on the compound Potts model.
A nvertex
by n
matrix with the kth column being the kth
sample.
Ulli Wolff (1989) Collective Monte Carlo Updating for Spin Systems Physical Review Letters vol. 62, no. 4, 361-364
Dai Feng (2008) Bayesian Hidden Markov Normal Mixture Models with Application to MRI Tissue Classification Ph. D. Dissertation, The University of Iowa
#Example 1: Generate 100 samples from a Potts model with the # neighborhood structure corresponding to a # second-order Markov random field defined on a # 3*3 2D graph. The number of colors is 2. # beta=0.7. All weights are equal to 1. neighbors <- getNeighbors(mask=matrix(1, 3, 3), neiStruc=rep(2,4)) Wolff(n=100, nvertex=9, ncolor=2, neighbors, beta=0.7)
#Example 1: Generate 100 samples from a Potts model with the # neighborhood structure corresponding to a # second-order Markov random field defined on a # 3*3 2D graph. The number of colors is 2. # beta=0.7. All weights are equal to 1. neighbors <- getNeighbors(mask=matrix(1, 3, 3), neiStruc=rep(2,4)) Wolff(n=100, nvertex=9, ncolor=2, neighbors, beta=0.7)