WikiDer > Алгоритм CN2

CN2 algorithm

В Алгоритм индукции CN2 это алгоритм обучения за индукция правила.[1] Он предназначен для работы даже при несовершенных обучающих данных. Он основан на идеях Алгоритм AQ и Алгоритм ID3. Как следствие, он создает набор правил, подобный тому, который создан AQ, но может обрабатывать зашумленные данные, такие как ID3.

Описание алгоритма

Алгоритму должен быть предоставлен набор примеров TrainingSet, которые уже были классифицированы, чтобы сформировать список правил классификации. Набор условий SimpleConditionSet, который может применяться отдельно или в комбинации к любому набору примеров, заранее определен для использования для классификации.

подпрограмма CN2 (TrainingSet), пусть ClassificationRuleList будет пустым, повторите, пусть BestConditionExpression будет Find_BestConditionExpression (TrainingSet), если BestConditionExpression не равно нулю, тогда пусть TrainingSubset будет примерами, охватываемыми BestConditionExpression, удалите из TrainingSet, примеры в TrainingSubset пусть MostCommonClass будет наиболее распространенный класс примеров в TrainingSubset добавляет к ClassificationRuleList правило «если« BestConditionExpression », то класс является« MostCommonClass »до тех пор, пока TrainingSet не станет пустым или BestConditionExpression не станет равным нулю, вернуть ClassificationRuleList
подпрограмма Find_BestConditionExpression (TrainingSet) пусть ConditionalExpressionSet будет пустым, пусть BestConditionExpression будет равным нулю, повторить пусть TrialConditionalExpressionSet будет набором условных выражений, {x и y, где x принадлежит ConditionalExpressionSet, а y принадлежит SimpleConditionSet}. удалите все формулы в TrialConditionalExpressionSet, которые либо находятся в ConditionalExpressionSet (т. е. неспециализированные), либо нулевые (например, big = y и big = n) для каждого выражения F в TrialConditionalExpressionSet, если F статистически значимо, а F лучше чем BestConditionExpression по заданным пользователем критериям при тестировании на TrainingSet, затем замените текущее значение BestConditionExpression на F, в то время как количество выражений в TrialConditionalExpressionSet> определяемое пользователем максимальное значение удалит худшее выражение из TrialConditionalExpressionSet, пусть ConditionalExpressionSet будет TrialConditionalExpressionSet до тех пор, пока ConditionalExpressionSet пуст, вернуть BestConditionExpression

Рекомендации

  1. ^ Кларк, П. и Ниблетт, Т. (1989) Алгоритм индукции CN2. Машинное обучение 3 (4): 261-283.

внешняя ссылка