【发布时间】:2015-12-14 19:54:03
【问题描述】:
所以我对 R 很陌生。我正在做一个项目,其数据集是鸟类时代的外观。我们有来自 95 个人的 >400,000 次观察。我的任务是这样的:
“如果这个图在线条旁边有一些数据点,会更有说服力。你可以在 lme4 的 getcall 中从 ranef 获取数据点。因此,运行没有年龄和年龄 2 项的模型。然后,拉出随机效应项(每个人的值),然后绘制它们(y = 随机效应,x = 年龄)。"
这是有问题的图表(它是使用我们的模型在 Excel 中制作的):Graph
所以我运行了这个
> lmbdna<-lmer(Gs ~ (1 | Individual) + Bin + year + Mass)
> ranef(lmbdna)
>$Individual
> plot(Age, ranef(lmbdna))
我得到了这个
xy.coords(x, y, xlabel, ylabel, log) 中的错误: “x”和“y”长度不同
我真的迷路了,我不知道如何将 ranefs 绘制到年龄。有没有办法将年龄与个人联系起来以消除该错误?
这是我的一些数据:
Indiv Age Mass MaxDepth Depth Gs PDBA Bin year
69903 12 1015 3.806 3.025 0.1854302 92.7151 A N
52712 20 957.5 3.806 3.025 0.204678 102.339 A T
55969 19 1002.5 3.806 3.025 0.222338 111.169 A T
64442 15 1040 3.806 3.025 0.1872954 93.6477 A T
76252 11 940 3.806 3.025 0.223136 111.568 A T
53391 21 1022.5 3.806 3.025 0.234452 117.226 A E
53391 21 1022.5 3.806 3.025 0.299438 149.719 A E
60117 18 937.5 3.806 3.025 0.1469442 73.4721 A E
60151 18 970 3.806 3.025 0.1941052 97.0526 A E
52712 20 957.5 3.855 3.025 0.1812926 90.6463 A T
52712 20 957.5 3.855 3.025 0.25101 125.505 A T
64442 15 1040 3.855 3.025 0.1850976 92.5488 A T
64442 15 1040 3.855 3.025 0.1026478 51.3239 A T
76252 11 940 3.855 3.025 0.235822 117.911 A T
78712 10 880 3.855 3.025 0.1638106 81.9053 A T
87819 7 1000 3.855 3.025 0.166391 83.1955 A T
90281 6 957.5 3.855 3.025 0.1493948 74.6974 A T
60151 18 970 3.855 3.025 0.1904232 95.2116 A E
69944 12 915 3.904 3.025 0.256504 128.252 A N
3260 24 960 3.904 3.025 0.168019 84.0095 A T
52712 20 957.5 3.904 3.025 0.270704 135.352 A T
64442 15 1040 3.904 3.025 0.1507102 75.3551 A T
71432 12 970 3.904 3.025 0.1238154 61.9077 A T
80538 15 917.5 3.904 3.025 0.236976 118.488 A E
76583 14 870 3.952 3.025 0.295982 147.991 A N
84420 7 1005 3.952 3.025 0.1861876 93.0938 A N
87819 7 1000 3.952 3.025 0.178179 89.0895 A T
53391 21 1022.5 3.952 3.025 0.1917954 95.8977 A E
53391 21 1022.5 3.952 3.025 0.1482036 74.1018 A E
53391 21 1022.5 3.952 3.025 0.1999868 99.9934 A E
53391 21 1022.5 3.952 3.025 0.276334 138.167 A E
60151 18 970 3.952 3.025 0.1776108 88.8054 A E
80538 15 917.5 3.952 3.025 0.188733 94.3665 A E
69944 12 915 4.001 3.025 0.2596 129.8 A N
3260 24 960 4.001 3.025 0.1824546 91.2273 A T
感谢任何帮助。谢谢
【问题讨论】:
-
你能提供一个最小可重现的例子吗?
-
您将
ranef(lmbdna)视为只是一个向量。将其分配给一个变量并提取以准确绘制您想要的部分。my_ranef = ranef(lmbdna)。使用str(my_ranef)看看那里有什么。您可能想要绘制类似my_ranef$Individual的图,但请确保顺序和所有内容都正确。 -
@NBATrends:我将数据的前几行添加到描述中,这有帮助吗?感谢您的回复!
-
@Gregor:我不太清楚你的意思,你能详细说明一下吗?抱歉,我的 R 语言还不是很先进。谢谢
-
@NBATrends,您的回答似乎已被删除,也帮助我解决了这个问题。谢谢!
标签: r plot lme4 mixed-models