马尔可夫链的 R 可视化 |手动更改转换矩阵中的值

R Visualization of markov chains | change values in transition matrix by hand

我运行一个R语言的马尔可夫模型,主要是为了得到马尔可夫图。

我想从转换矩阵中排除概率 < 0,4 的所有行(在这种情况下,应删除从 start 到 c2 的行。)。我通过将这些值设置为 0 来尝试此操作。但是更改转换矩阵中的值会导致错误:请参见下文:我用“################# 标记了感兴趣的位置######”(第 76 行)

# creating a data sample
df1 <- data.frame(path = c('c1 > c2 > c3', 'c1', 'c2 > c3'), conv = c(1, 0, 0), conv_null = c(0, 1, 1)) # original
df1

# calculating the models
mod1 <- markov_model(df1,
                     var_path = 'path',
                     var_conv = 'conv',
                     var_null = 'conv_null',
                     out_more = TRUE)          
mod1                 


# extracting the results of attribution:
df_res1 <- mod1$result
df_res1

# extracting a transition matrix: 
df_trans1 <- mod1$transition_matrix                
df_trans1

df_trans1 <- dcast(df_trans1, channel_from ~ channel_to, value.var = 'transition_probability')
df_trans1



### plotting the Markov graph ###
df_trans <- mod1$transition_matrix
df_trans

# adding dummies in order to plot the graph
df_dummy <- data.frame(channel_from = c('(start)', '(conversion)', '(null)'),
                       channel_to = c('(start)', '(conversion)', '(null)'),
                       transition_probability = c(
                         0,
                         1,
                         1
                         )) # die Übergangswarhscheinlichkeit von zu sich selber eintragen
df_dummy

df_trans <- rbind(df_trans, df_dummy)
df_trans

# ordering channels
df_trans$channel_from <- factor(df_trans$channel_from,
                                levels = c('(start)', '(conversion)', '(null)',
                                           'c1',
                                           'c2',
                                           'c3'
                                           ))

df_trans$channel_from

df_trans$channel_to <- factor(df_trans$channel_to,
                              levels = c('(start)', '(conversion)', '(null)', 
                                         'c1',
                                         'c2',
                                         'c3'
                              ))

df_trans$channel_to

df_trans <- dcast(df_trans, channel_from ~ channel_to, value.var = 'transition_probability')
df_trans


# creating the markovchain object
trans_matrix <- matrix(data = as.matrix(df_trans[, -1]),
                       nrow = nrow(df_trans[, -1]), ncol = ncol(df_trans[, -1]),
                       dimnames = list(c(as.character(df_trans[, 1])), c(colnames(df_trans[, -1]))))

trans_matrix[is.na(trans_matrix)] <- 0
trans_matrix


####################### I want to delete transition-propabilities < 0.4 from markov graph by setting these values to 0.
trans_matrix[trans_matrix < 0.4] <- 0 # 


####################### After doing this, the following querie gives me an error: Error! Row sums not equal to one check positions: 1
trans_matrix1 <- new("markovchain", transitionMatrix = trans_matrix)  
trans_matrix1

# plotting the graph
plot(trans_matrix1, edge.arrow.size = 0.5, size = 100, cex.main = 0.11, cex.lab = 0.5, cex.axis = 0.5)

如果将一些正项设置为 0,则转移矩阵不再是转移矩阵,因为行总和必须等于 1。所以 new("markovchain", ....) 不适用于这样的矩阵。

但是如果你只想要情节,这可以通过修改插槽 transitionMatrix:

library(markovchain)
tm <- rbind(c(0.3, 0.5, 0.2), c(0.1, 0.1, 0.8), c(0.6, 0.2, 0.2))
states <- c("a", "b", "c")
mc <- new("markovchain", states=states, transitionMatrix=tm, name="X")

tm[tm<0.4] <- 0
dimnames(tm) <- list(states, states)
mc@transitionMatrix <- tm

plot(mc)