Дерево решений Анализ вопроса

В настоящее время я работаю над проблемой с R. Я хочу применить дерево классификации к набору данных, но результат кажется неправильным, так как я уже решил ту же проблему, используя Weka, и получил другие результаты.

Я получил набор данных, содержащийся в CSV-файле следующим образом:

age,menopause,tumor.size,inv.nodes,node.caps,deg.malig,breast,breast.quad,irradiat,class
40-49,premeno,15-19,0-2,yes,3,right,left_up,no,recurrence-events
50-59,ge40,15-19,0-2,no,1,right,central,no,no-recurrence-events
50-59,ge40,35-39,0-2,no,2,left,left_low,no,recurrence-events
40-49,premeno,35-39,0-2,yes,3,right,left_low,yes,no-recurrence-events
40-49,premeno,30-34,3-5,yes,2,left,right_up,no,recurrence-events

и это сценарий:

#Open r file
cancer = read.csv("cancer.csv")
#Data Exploration
summary(cancer)
str(cancer)
#Divide into test and train sets 
set.seed(1234) 
ind <- sample(2, nrow(cancer), replace=TRUE, prob=c(0.7, 0.3))
trainData <- cancer[ind==1,]
testData <- cancer[ind==2,]
#Build the model
library(party)
cancermodel <- class ~ age + menopause + tumor.size + inv.nodes + node.caps + deg.malig + breast + breast.quad + irradiat
cancertree <- ctree(cancermodel,trainData)
table(predict(cancertree),trainData$class)
#Draw tree
plot(cancertree, type="simple")
#Testset
testPred <- predict(cancertree, newdata = testData)
table(testPred, testData$class)

2 ответа

Деревья решений имеют много разных реализаций алгоритмов в R (tree, rpart, party) и в Weka (J48, LMT, DecisionStump), и разные алгоритмы могут создавать разные деревья решений для одного и того же набора данных (некоторые работают, максимизируя прирост информации / индекс Джини некоторые используют тесты гипотез с хи-квадрат статистикой).

Даже любой данный алгоритм будет создавать разные деревья решений с разными входными параметрами (сокращенные / необработанные, минимальные # точки данных в узле для разделения и т. Д.).

Кроме того, как отмечает @RomRom, дерево решений не является очень надежной моделью, в том смысле, что небольшое изменение в обучающих данных может привести к совершенно другому дереву.

Учитывая все это, трудно создать одно и то же дерево решений в R и Weka, и даже если вы можете, вам нужно очень тщательно настроить параметры модели, что может потребовать большого количества экспериментов.

Ниже приведен пример набора данных радужной оболочки с несколькими моделями дерева решений R и моделями дерева решений RWeka (как видно из построенных деревьев, разные модели генерируют разные деревья с одинаковой радужной оболочкой набора данных).

library(RWeka)
m1 <- J48(Species ~ ., data = iris)
if(require("partykit", quietly = TRUE)) plot(m1)

введите описание изображения здесь

library(rpart)
m2 <- rpart(Species ~ ., data = iris)
library(rpart.plot)
prp(m2)

введите описание изображения здесь

library(party)
m3 <- ctree(Species ~ ., data = iris)
plot(m3)

введите описание изображения здесь

Вы выбрали случайную выборку здесь в своем коде в пределах R: ind <- sample (2, nrow (рак), replace = TRUE, prob = c (0.7, 0.3))

как вы копировали и использовали одну и ту же случайную выборку в Weka? деревья - очень ненадежные модели и могут быстро меняться в зависимости от разных файлов данных.

Другие вопросы по тегам