classification tree implementation in mathematica

I want to implement simple classification tree (binary classification) using Mathematica.

How can I implement a binary tree in Mathematica? Is there is a symbol for doing that?


I'd say it depends on what you want to do with the data structure.

You can exploit the fact that Mathematica expressions themselves are trees.

If only the leaf nodes are relevant, then use nested lists, eg {{1, {2, 3}}, 4} . If the other node need to carry some data too, then you can use something like this:

tree[1][tree[2][a, b], tree[3][c, tree[4][d, e]]]

See the structure like this:

{{1, {2, 3}}, 4} // TreeForm
tree[1][tree[2][a, b], tree[3][c, tree[4][d, e]]] // TreeForm

The next question is how to implement algorithm X on such a data structure.


Among the new objects in MMA 8 are TreeGraph, CompleteKaryTree, and KaryTree. The latter two objects give binary trees by default. I don't know how efficient they are for intensive computation but they do seem well-suited for displaying classifications. And there are many predicates and options for manipulating and displaying them.

Here's an example of a classification tree from [Breiman, L. Classification and Regression Trees: Chapman & Hall/CRC, 1984.]. It concerns 3 questions to determine whether a cardiac patient is likely to die within 30 days if not treated.

KaryTree[9, 2, 
   VertexLabels -> {1 -> "Blood pressure > 91 ?", 2 -> "Age > 62.5?", 
                    4 -> "Sinus tachycardia ?", 8 -> "< 30 days"}, 
   EdgeLabels -> {1 [UndirectedEdge] 2 -> "yes", 
                  1 [UndirectedEdge] 3 -> "no", 2 [UndirectedEdge] 4 -> "yes", 
                  2 [UndirectedEdge] 5 -> "no", 4 [UndirectedEdge] 8 -> "yes", 
                  4 [UndirectedEdge] 9 -> "no"}, ImagePadding -> 20]

分类图

I'd like to get rid of the two unused nodes on the right, but have not figured out a an elegant way to do it. So I think I'll post a simple question about that on SO.


Personally I don't quite know, but there appears to be an article about the very subject on the Wolfram site, found here. It might not answer your question, but it will hopefully give you some insight!

链接地址: http://www.djcxy.com/p/35578.html

上一篇: 选择性地收集树中的节点

下一篇: mathematica中的分类树实现