Як виправити: помилка в do_one(nmeth): na/nan/inf у зовнішньому виклику функції (arg 1)
Помилка, з якою ви можете зіткнутися в R:
Error in do_one(nmeth): NA/NaN/Inf in foreign function call (arg 1)
Ця помилка виникає, коли ви намагаєтесь виконати кластеризацію k-середніх у R , але кадр даних, який ви використовуєте, містить одне або кілька відсутніх значень.
Цей посібник пояснює, як саме виправити цю помилку.
Як відтворити помилку
Припустімо, що ми маємо наступний кадр даних у R із відсутнім значенням у другому рядку:
#create data frame df <- data. frame (var1=c(2, 4, 4, 6, 7, 8, 8, 9, 9, 12), var2=c(12, 14, 14, 8, 8, 15, 16, 9, 9, 11), var3=c(22, NA, 23, 24, 28, 23, 19, 16, 12, 15)) row. names (df) <- LETTERS[1:10] #view data frame df var1 var2 var3 At 2 12 22 B 4 14 NA C 4 14 23 D 6 8 24 E 7 8 28 F 8 15 23 G 8 16 19 H 9 9 16 I 9 9 12 D 12 11 15
Якщо ми спробуємо використати функцію kmeans() для кластеризації k-means на цьому кадрі даних, ми отримаємо помилку:
#attempt to perform k-means clustering with k = 3 clusters km <- kmeans(df, centers = 3 ) Error in do_one(nmeth): NA/NaN/Inf in foreign function call (arg 1)
Як виправити помилку
Найпростіший спосіб виправити цю помилку – просто використати функцію na.omit() , щоб видалити рядки з відсутніми значеннями з кадру даних:
#remove rows with NA values df <- na. omitted (df) #perform k-means clustering with k = 3 clusters km <- kmeans(df, centers = 3) #view results km K-means clustering with 3 clusters of sizes 4, 3, 2 Cluster means: var1 var2 var3 1 5.5 14.250000 21.75000 2 10.0 9.666667 14.33333 3 6.5 8.000000 26.00000 Vector clustering: ACDEFGHIJ 1 1 3 3 1 1 2 2 2 Within cluster sum of squares by cluster: [1] 46.50000 17.33333 8.50000 (between_SS / total_SS = 79.5%) Available components: [1] "cluster" "centers" "totss" "withinss" "tot.withinss" [6] "betweenss" "size" "iter" "ifault"
Зверніть увагу, що алгоритм кластеризації k-середніх працює успішно, коли ми видаляємо рядки з відсутніми значеннями з кадру даних.
Бонус: повний покроковий посібник із кластеризації k-середніх у R
Додаткові ресурси
Як виправити в R: NAs, введені примусово
Як відремонтувати в R: індекс поза межами
Як виправити в R: довжина довшого об’єкта не є кратною довжині коротшого об’єкта