BookmarkSubscribeRSS Feed
🔒 This topic is solved and locked. Need further help from the community? Please sign in and ask a new question.
JTho
Calcite | Level 5

I am using SAS EM to grow a Decision Tree. I was asked by a reviewer if a "minimum difference" could be set at the terminal nodes. That is, could a threshold be set such that a parent node will not split unless the difference in the % event reaches a critical threshold value across nodes?

 

For example: Prune back to the parent node, any terminal nodes where the % difference is less than 5%.

 

The question was raised in the context of "clinically-meaningful" differences across terminal nodes vs. "statistically-meaningful" differences.

 

Is this minimal difference something I could manually set in SAS-EM?

 

Thank you!

Josh 

1 ACCEPTED SOLUTION

Accepted Solutions
PadraicGNeville
SAS Employee

No:  The procedure that underlies the  EM decision tree node does not have an option to prune close siblings. One would have to resort to advanced SAS data step programming, outputing the nodes statistics, searching for leaves that are too close, and pruning their parents. Some key elements might be:

 

PROC ARBOR INMODEL = savedTreeDataTable;

SAVE STATSBYNODE= statsDataTable  TOPOLOGY=topologyDataTable.

 

Write data step code to use the topologyDataTable to add a ParentNode variable in the statsDataTable, search the statsDataTable for siblings that are too close, and outputting a macro variable containing a list of the ParentNodes of the close siblings.  Then:

 

PROC ARBOR INMODEL=savedTreeDataTable;

PRUNE &listOfNodes;

SAVE model=prunedTreeDataTable;

 

This is the simplist way I can think of doing it.

-Padraic

 

 

View solution in original post

1 REPLY 1
PadraicGNeville
SAS Employee

No:  The procedure that underlies the  EM decision tree node does not have an option to prune close siblings. One would have to resort to advanced SAS data step programming, outputing the nodes statistics, searching for leaves that are too close, and pruning their parents. Some key elements might be:

 

PROC ARBOR INMODEL = savedTreeDataTable;

SAVE STATSBYNODE= statsDataTable  TOPOLOGY=topologyDataTable.

 

Write data step code to use the topologyDataTable to add a ParentNode variable in the statsDataTable, search the statsDataTable for siblings that are too close, and outputting a macro variable containing a list of the ParentNodes of the close siblings.  Then:

 

PROC ARBOR INMODEL=savedTreeDataTable;

PRUNE &listOfNodes;

SAVE model=prunedTreeDataTable;

 

This is the simplist way I can think of doing it.

-Padraic

 

 

hackathon24-white-horiz.png

The 2025 SAS Hackathon has begun!

It's finally time to hack! Remember to visit the SAS Hacker's Hub regularly for news and updates.

Latest Updates

How to choose a machine learning algorithm

Use this tutorial as a handy guide to weigh the pros and cons of these commonly used machine learning algorithms.

Find more tutorials on the SAS Users YouTube channel.

Discussion stats
  • 1 reply
  • 1161 views
  • 1 like
  • 2 in conversation