如何使用dplyr生成列依赖随机变量

我想生成一列正常随机变量,其中均值在dep变量中定义.但是,我得到了非随机结果.

我知道还有其他方法可以像应用函数一样(sapply(1:5,rnorm,n = 1)),但我很想知道如何使用dplyr来实现它以及为什么我会犯错误.

library(dplyr)
data_frame(dep = 1:5) %>% 
        mutate(normal_mean = rnorm(1,mean=dep))
Source: local data frame [5 x 2]

dep normal_mean
1   1    1.574045
2   2    1.574045
3   3    1.574045
4   4    1.574045
5   5    1.574045

解决方法

我认为rowwise很慢.相反,你应该只更正rnorm的第一个参数:

data.frame(dep=1:5) %>% mutate(normal_mean = rnorm(n(),mean=dep))

相关文章

什么是设计模式一套被反复使用、多数人知晓的、经过分类编目...
单一职责原则定义(Single Responsibility Principle,SRP)...
动态代理和CGLib代理分不清吗,看看这篇文章,写的非常好,强...
适配器模式将一个类的接口转换成客户期望的另一个接口,使得...
策略模式定义了一系列算法族,并封装在类中,它们之间可以互...
设计模式讲的是如何编写可扩展、可维护、可读的高质量代码,...