r语言 - 用fitdist函数估计尺度和形状参数的缩放(fitdistrplus包)



如标题所述,我在R (fitdistrplus包)中有fitdist函数的缩放问题。

请看下面的代码:

# Initialize arrays for storing result
fit_store_scale <- rep(NA, 3)
fit_store_shape <- rep(NA, 3)
# load data
data1 <- c(7.616593e-05, 5.313253e-05, 1.604328e-04, 6.482365e-05,
           4.217499e-05, 6.759114e-05, 3.531301e-05, 1.934228e-05,
           6.263665e-05, 8.796205e-06)
data2 <- c(7.616593e-06, 5.313253e-06, 1.604328e-05, 6.482365e-06,
           4.217499e-06, 6.759114e-06, 3.531301e-06, 1.934228e-06,
           6.263665e-06, 8.796205e-07)
data3 <- c(7.616593e-07, 5.313253e-07, 1.604328e-06, 6.482365e-07,
           4.217499e-07, 6.759114e-07, 3.531301e-07, 1.934228e-07,
           6.263665e-07, 8.796205e-08)
# form data frame
data <- data.frame(data1, data2, data3)
# set scaling factor
scaling <- 1        #works without warnings and errors at:    
                    #10000 (data1), 100000 (data2) or
                    #1000000 (data3)
# store scale and shape parameter of data1, data2 and data3 in Array
for(i in 1:3)
{
    fit.w1 <- fitdist(data[[i]]*scaling,"weibull", method = "mle")
    fit_store_scale[i] <- fit.w1$estimate[[2]]*1/scaling
    #1/scaling is needed for correcting scale parameter
    fit_store_shape[i] <- fit.w1$estimate[[1]]
}

我有三个数据向量,它们存储在一个数据帧中。现在我想用fitdist函数对每列数据(data1, data2data3)分别估计尺度和形状参数,最后分别存储在fit_store_scalefit_store_shape中。

这里的问题是fitdist函数没有适当的缩放因子就不能工作,data1, data2data3需要不同的因子。我正在寻找一种解决方案,以确定每个数据列的最佳缩放因子,从而使fitdist函数最终发挥作用。

如果你不完全依赖于fitdist,你可以使用一些更健壮的东西——下面的方法适合Weibull与log尺度上的参数,并使用Nelder-Mead而不是基于梯度的方法。拟合这些数据似乎没有任何问题。

dd <- data.frame(data1,data2,data3)
library("bbmle")
fx <- function(x) {
    m1 <- mle2(y~dweibull(shape=exp(logshape),scale=exp(logscale)),
           data=data.frame(y=x),start=list(logshape=0,logscale=0),
           method="Nelder-Mead")
    exp(coef(m1))
}
t(sapply(dd,fx))  ## not quite the output format you asked for,
                  ##  but easy enough to convert.
##       logshape     logscale
## data1 1.565941 6.589057e-05
## data2 1.565941 6.589054e-06
## data3 1.565941 6.589055e-07

这种方法对于任何具有标准分布(d*())函数的分布都应该工作得相当好。

解决这个问题的一种方法是继续尝试通过缩放10^j:

来适应分布。
for(i in 1:3)
{
  j <- 0
  while(inherits(try(fitdist(data[[i]] * 10^j, "weibull", method = "mle"), silent = TRUE), "try-error"))
  {
    j <- j + 1
  }
  cat("nFor data[[", i, "]], used j =", j, "nn")
  fit.w1 <- fitdist(data[[i]] * 10^j, "weibull", method = "mle")
  fit_store_scale[i] <- fit.w1$estimate[[2]] * 1/10^j
  #1/scaling is needed for correcting scale parameter
  fit_store_shape[i] <- fit.w1$estimate[[1]]
}

# For data[[ 1 ]], used j = 2 
# For data[[ 2 ]], used j = 3 
# For data[[ 3 ]], used j = 4 
# > fit_store_scale
# [1] 6.590503e-05 6.590503e-06 6.590503e-07
# > fit_store_shape
# [1] 1.56613 1.56613 1.56613

也就是说,对于data[[1]],我们成功地使用了j = 2(通过10^2 == 100缩放),对于data[[2]],我们使用了j = 3 == 10^3 == 1,000,对于data[[3]],我们使用了j = 4 == 10^4 == 10,000

在一天结束时,这将找到10的最小次幂来缩放数据并实现匹配。参见?fitdist下的#14示例,了解此方法的变体/theme。

相关内容

  • 没有找到相关文章

最新更新