在执行lm.fit(x, y, offset = offset, singular.ok = singular.ok, ...)时出现错误:'y'中存在NA/NaN/Inf,已尝试所有可能的方法。

4

这里我的数据集是pd,我把它分成了训练数据和测试数据,分别为pd_train1pd_train2

    sku national_inv lead_time in_transit_qty forecast_3_month forecast_6_month
1 3921548            8        12              0                0                0
2 3191009           83         2             33              157              377
3 2935810            8         4              0                0                0
4 2205847           31         4             63               70              160
5 4953497            3        12              0                0                0
6 2286884            0         8              0                0                0
  forecast_9_month sales_1_month sales_3_month sales_6_month sales_9_month min_bank
1                0             1             1             2             5        2
2              603            44            98           148           156       53
3                0             0             0             1             1        0
4              223            27            90           164           219        0
5                0             0             0             0             0        0
6                0             0             0             0             0        0
  potential_issue pieces_past_due perf_6_month_avg perf_12_month_avg local_bo_qty
1               0               0             0.63              0.75            0
2               0               0             0.68              0.66            0
3               0               0             0.73              0.78            0
4               0               0             0.73              0.78            0
5               0               0             0.81              0.74            0
6               0               0             0.91              0.96            0
  deck_risk oe_constraint ppap_risk stop_auto_buy rev_stop went_on_backorder  data
1         0             0         0             1        0                No train
2         0             0         0             1        0                No train
3         0             0         0             1        0                No train
4         0             0         1             1        0                No train
5         0             0         0             1        0                No train
6         0             0         0             1        0                No train

我想为我的训练数据 pd_train1 创建一个 lm 模型,但是我遇到了以下错误:

> fit=lm(went_on_backorder~.,data=pd_train1)
Error in lm.fit(x, y, offset = offset, singular.ok = singular.ok, ...) : 
  NA/NaN/Inf in 'y'
In addition: Warning message:
In storage.mode(v) <- "double" : NAs introduced by coercion

我试图搜索无限值:

sapply(pd_train1, function(x) sum(is.infinite(x)))
             sku      national_inv         lead_time    in_transit_qty  forecast_3_month 
                0                 0                 0                 0                 0 
 forecast_6_month  forecast_9_month     sales_1_month     sales_3_month     sales_6_month 
                0                 0                 0                 0                 0 
    sales_9_month          min_bank   potential_issue   pieces_past_due  perf_6_month_avg 
                0                 0                 0                 0                 0 
perf_12_month_avg      local_bo_qty         deck_risk     oe_constraint         ppap_risk 
                0                 0                 0                 0                 0 
    stop_auto_buy          rev_stop went_on_backorder              data 
                0                 0                 0                 0 

我在准备制作线性模型时,我的训练数据中存在NA/NaN值。

     sku      national_inv         lead_time    in_transit_qty  forecast_3_month 
                0                 0                 0                 0                 0 
 forecast_6_month  forecast_9_month     sales_1_month     sales_3_month     sales_6_month 
                0                 0                 0                 0                 0 
    sales_9_month          min_bank   potential_issue   pieces_past_due  perf_6_month_avg 
                0                 0                 0                 0                 0 
perf_12_month_avg      local_bo_qty         deck_risk     oe_constraint         ppap_risk 
                0                 0                 0                 0                 0 
    stop_auto_buy          rev_stop went_on_backorder 
                0                 0                 0 


Inf %in% pd_train1$went_on_backorder
1] FALSE

NaN %in% pd_test$went_on_backorder
1] FALSE

从此我无法获取数据集中的NA / NaN / Inf值 请问有人能帮我理解为什么会出现这个错误吗? 这里 went_on_backorder 是我的目标变量。

你能提供一个可重现的例子吗?在建模中你使用了多少数据点? - Roman Luštrik
有大约250078个数据点,我该如何提供可重复的示例呢?你有什么想法吗?我也不明白你到底编辑了什么? - Aniket Rele
理想情况下,您应该模拟一个数据集,以产生手头的错误。请参阅此链接以获取一些想法:https://dev59.com/eG025IYBdhLWcg3whGSx - Roman Luštrik
2个回答

3

went_on_backorder是一个因素。线性回归需要一个数字响应变量。

要使用逻辑回归,请使用基本R中的glm或诸如vgam之类的包。以下是一个简短的示例:

pd_train1 <- data.frame('went_on_backorder' = c('No','Yes','Yes'), 'lead_time' = 1:3)
model <- glm(went_on_backorder ~ ., data = pd_train1, family = 'binomial')

您可以预测您的课程:

predict(model, newdata = data.frame('lead_time' = c(0,1,2.5,3.5)), type = "response")

1

went_on_backorder 不是一个数值变量。 lm 无法处理非数值的因变量。请查阅 逻辑回归


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接