我有一个向量列表,对于列表中的每个向量,我想提取元素并将它们的值用作函数中的参数。以下是我到目前为止所提出的一般概念。
#Function to convert parametric values (stored in vector) to multivariate normal random data
ParamsToDat = function(X){
vec = X
MultN = rmvnorm(vec[4],c(vec[2],vec[3],matrix(c(vec[5],vec[1],vec[1],vec[6]), 2, 2, byrow = FALSE)))
return(MultN)
}
# Create list of randomly generated matrices based on parameters
GenData = function(MeanPre,MeanPost,Cov,SampSize,SampSD,IndVar1,IndVar2){
#Use GenParams function to generate list of vectors each of length 6
Params = GenParams(MeanPre,MeanPost,Cov,SampSize,SampSD,IndVar1,IndVar2)
#Use lapply function to create list of matrices of multivariate normal data
MatList = lapply(X = Params, FUN = ParamsToDat)
MultN = list(Matlist = Matlist, Params = Params)
return(MultN)
}
列表Params中的每个元素都是长度为6的向量。我希望函数ParamsToDat提取列表中向量的元素,并将它们用作参数来生成多元正态数据矩阵。该矩阵将替换从中导出值的向量。
我显然在使用ParamsToDat函数或lapply函数或两者都搞乱了,因为它不起作用。任何想法我怎么能做到这一点?
答案 0 :(得分:0)
主要问题是R区分大小写,所以行
MultN = list(Matlist = Matlist, Params = Params)
应该是
MultN = list(Matlist = MatList, Params = Params)
请注意,我已将Matlist
更改为MatList
。
我认为放错位置)
仍然会给您一个不会导致错误的问题
MultN = rmvnorm(vec[4],c(vec[2],vec[3],matrix(c(vec[5],vec[1],vec[1],vec[6]), 2, 2, byrow = FALSE)))
我猜你真的想要
MultN = rmvnorm(vec[4],c(vec[2],vec[3]),matrix(c(vec[5],vec[1],vec[1],vec[6]), 2, 2, byrow = FALSE))
在你的代码中,你花了一些时间来制作一个矩阵,看起来它应该是rmvnorm()
调用中的方差 - 协方差矩阵,但错位的)
将会变成那个回到一个向量中,所以当你可能期望有两个均值和一个有趣的方差 - 协方差矩阵时,你最终得到六个均值和方差 - 协方差矩阵diag(6)
。
希望这会有所帮助。祝你好运!
答案 1 :(得分:0)
这是我的解决方案。谢谢你的回复。
### This function accepts a vector of length six and converts it to bivariate normal data ###
VecToNorm = function(vec){
BivNorm = abs(round(rmvnorm(vec[4],c(vec[2],vec[3]),matrix(c(vec[5],vec[1],vec[1],vec[6]), 2, 2, byrow = FALSE))))
return(BivNorm)
}
### Function to convert parametric values from list of vectors to multivariate normal random data ###
ParamsToDat2 = function(Params){
Data = lapply(Params, FUN = VecToNorm)
}