用循环在矩阵上应用 FUN

Posted

技术标签:

【中文标题】用循环在矩阵上应用 FUN【英文标题】:Apply FUN on a matrix with a loop 【发布时间】:2018-05-12 16:04:53 【问题描述】:

对于受限和非受限模型,我需要从 nlminb 函数中找到 $par$objective 的值。受限模型是初始模型中每对可能行的总和。初始模型以矩阵nn 的形式呈现。例如,每列的总和应按对计算:1,2; 1,3; 1,4 等所有可能的对。

> nn
      [,1] [,2] [,3] [,4] [,5] [,6] [,7] [,8] [,9]
 [1,]    3    0    0    0    0    0    0    0    1
 [2,]   55   73   59    3    1    0   16    0   12
 [3,]   10    0   14    0    0    0    3    0    1
 [4,]    3    2   21   14    0    0    0    0    0
 [5,]  145   34  300   24    0    0   26    0    3
 [6,]  883  298 1561   82    6    7  202    7   99
 [7,]   20   19  135   89    0    8    3    2    0
 [8,]  533  369 2026  280   18    4  294    6   75
 [9,] 2820  641 4082  611   28   17 1052   75  253
[10,]  662  175 1140  301    8    9  214    2   48
[11,] 2206  342 1989  330   23   12  715   21  277
[12,]  210  350 1463  207   10    7   23    7   30 

我的代码如下:

z_Obj<-list()
z_Par<-list()
for(i in 1:nrow(nn)) 
  for(j in 2:nrow(nn))
    if (j!=i)
      f_2<-function(par,n)
        u1<-par[1]
        u2<-par[2]
        u3<-par[3]
        u4<-par[4]
        u5<-par[5]
        u6<-par[6]
        u7<-par[7]
        u8<-par[8]
        u9<-par[9]
        n=nn[i,1:9]+nn[j,1:9]
        -sum(n*log(par/(sum(par))))
      
      z<-nlminb(c(1,0,0,0,0,0,0,0,0),objective = f_2,lower = 0.000001, upper = Inf)
      z_Obj[[i]]<-z$objective
      z_Par[[i]]<-z$par
  


问题是代码没有估计所有可能的对的$par$objective,并且只给出像1,1 这样的对的结果; 2,2; 3,3。正是那些我不需要运行的对。 请您帮忙解决我的代码问题吗?谢谢! :)

当我运行 dput(nn) 时,它给了我这个结果:

> dput(nn)
structure(c(3L, 55L, 10L, 3L, 145L, 883L, 20L, 533L, 2820L, 662L, 
2206L, 210L, 0L, 73L, 0L, 2L, 34L, 298L, 19L, 369L, 641L, 175L, 
342L, 350L, 0L, 59L, 14L, 21L, 300L, 1561L, 135L, 2026L, 4082L, 
1140L, 1989L, 1463L, 0L, 3L, 0L, 14L, 24L, 82L, 89L, 280L, 611L, 
301L, 330L, 207L, 0L, 1L, 0L, 0L, 0L, 6L, 0L, 18L, 28L, 8L, 23L, 
10L, 0L, 0L, 0L, 0L, 0L, 7L, 8L, 4L, 17L, 9L, 12L, 7L, 0L, 16L, 
3L, 0L, 26L, 202L, 3L, 294L, 1052L, 214L, 715L, 23L, 0L, 0L, 
0L, 0L, 0L, 7L, 2L, 6L, 75L, 2L, 21L, 7L, 1L, 12L, 1L, 0L, 3L, 
99L, 0L, 75L, 253L, 48L, 277L, 30L), .Dim = c(12L, 9L))

【问题讨论】:

您能否运行dput(nn) 并将输出粘贴到您的问题中? @ClausWilke 我为 dput(nn) 添加了输出 【参考方案1】:

此代码生成行和列的所有组合并计算其总和。

# generate matrix of all combinations    
row_comb <- combn(nrow(nn), 2)
col_comb <- combn(ncol(nn), 2)

# predefine vector for results
row_sums <- rep(NULL, ncol(row_comb))
col_sums <- rep(NULL, ncol(col_comb))

# calculate sums of all combinations
for (i in 1:ncol(col_comb)) (
  col_sums[i] <-  (sum (nn [, col_comb [,i]]))
)

for (i in 1:ncol(row_comb)) (
  row_sums[i] <-  (sum (nn [row_comb [,i], ] ))
)

我希望这有助于解决您的问题! :-)

【讨论】:

以上是关于用循环在矩阵上应用 FUN的主要内容,如果未能解决你的问题,请参考以下文章

Matlab中用内建函数代替for循环

关于循环矩阵的一些理解和应用

如何用matlab生成一个3阶和5阶魔方矩阵

实验四-图的实现与应用

如何应用循环遍历 R 中的矩阵

在矩阵上使用带有均值函数的 mapply