【发布时间】:2018-08-05 15:36:39
【问题描述】:
我有以下数据:
Company Year Variables Data
ABC 2000 Revenue 10
ABC 2001 Revenue 15
ABC 2002 Revenue 12
ABC 2003 Revenue 25
ABC 2004 Revenue 30
CDE 2000 Revenue 5
CDE 2001 Revenue 8
CDE 2002 Revenue 17
CDE 2003 Revenue 9
CDE 2004 Revenue 34
#etc
我想计算过去 3 年的复合年增长率 (CAGR)。
例如,每家公司的 3 年复合年增长率结果将是:
Company Year Variables Data CAGR
ABC 2000 Revenue 10 NA
ABC 2001 Revenue 15 NA
ABC 2002 Revenue 12 6.27%
ABC 2003 Revenue 25 18.56%
ABC 2004 Revenue 30 35.72%
CDE 2000 Revenue 5 NA
CDE 2001 Revenue 8 NA
CDE 2002 Revenue 17 50.37%
CDE 2003 Revenue 9 4.00%
CDE 2004 Revenue 34 25.99%
我按年份在数据中使用以下公式:
CAGR for 2004=((LastYear/PreviousYear)^(1/n))-1
For example for n = 2
LastYear =2004
PreviousYear =2004-2 = 2002
尝试使用 R 代码计算 2004 年与 2002 年的复合年增长率:
library(tibble)
library(dplyr)
library(lubridate)
year<-c(rep(2000:2004,2))
company<-rep(c("ABC","CDE"),5)
variable<-rep("revenue",10)
data<-c(10,15,12,25,30,5,8,17,9,34)
tibdf<-tibble(company,year,variable,data)
View(tibdf)
#revenue2004<-tibdf%>%filter(year==2004)%>%select(company,data)
#revenue2002<-tibdf%>%filter(year==2001)%>%select(company,data)
计算 CAGR(来自Plot Compound Annual Growth Rate (3 independent variables) in R)
annual.growth.rate <- function(a){
T1 <- max(a$year) - min(a$year)+1
FV <- a[which(a$year == max(a$year)),"data"]
SV <- a[which(a$year == min(a$year)),"data"]
cagr <- ((FV/SV)^(1/T1)) -1
}
将 tibdf 用于 in 函数。 不幸的是,我无法将函数应用于我的数据。
感谢您的帮助。
【问题讨论】:
标签: r