Q: KNN in R — strange behavior

后端 未结 1 1971
小蘑菇
小蘑菇 2021-01-29 05:45

Does anyone know why the following KNN R code gives different predictions for different seeds? This is strange as K<-5, and thus the majority is well defined. In addition, t

相关标签:
1条回答
  • 2021-01-29 06:35

    The knn function calls an underlying C function (line 122) called VR_knn, which includes a step that introduces "fuzz" or a small value (epsilon, EPS). Looks like your example parameter values may be hitting up against that "fuzz" step. Evidence for this is the fact that rounding your values to 4 digits yields consistency. As such:

    library(class)
    train <- rbind(
      c(0.0626015,  0.0530052,  0.0530052,  0.0496676,  0.0530052,  0.0626015),
      c(0.0565861,  0.0569546,  0.0569546,  0.0511377,  0.0569546,  0.0565861),
      c(0.0538332,  0.057786,   0.057786,   0.0506127,  0.057786,   0.0538332),
      c(0.059033,   0.0541484,  0.0541484,  0.0501926,  0.0541484,  0.059033),
      c(0.0587272,  0.0540445,  0.0540445,  0.0505076,  0.0540445,  0.0587272),
      c(0.0578095,  0.0564349,  0.0564349,  0.0505076,  0.0564349,  0.0578095)
    )
    trainLabels <- c(1,1,0,0,1,0)
    test  <- c(0.1923241, 0.1734074, 0.1734074, 0.1647619, 0.1734074, 0.1923241)
    K <- 5
    
    train <- round(train,4)
    
    seed <- 494139
    set.seed(seed)
    pred <- knn(train=train, test=test, cl = trainLabels, k=K)
    message("predicted: ", pred, ", seed: ", seed)
    # predicted: 0, seed: 494139
    
    seed <- 5371
    set.seed(seed)
    pred <- knn(train=train, test=test, cl = trainLabels, k=K)
    message("predicted: ", pred, ", seed: ", seed)
    # predicted: 0, seed: 5371
    
    0 讨论(0)
提交回复
热议问题