dendrogram​関数の結果から、閾値​以下のグループ数をカ​ウントする方法につい​て

3 ビュー (過去 30 日間)
denpika
denpika 2018 年 7 月 17 日
コメント済み: denpika 2018 年 7 月 18 日
以下のコードを実行すると閾値0.4以下のノードが4色に塗り分けられますが、塗り分けられた色の数(グループの数)をカウントする方法はないでしょうか?
rng('default')
X = rand(20,2);
tree = linkage(X,'average');
dendrogram(tree,0,'ColorThreshold',0.4);

採用された回答

michio
michio 2018 年 7 月 17 日
かなり不格好ですが・・ラインハンドル H から全ての色を確認し、何種類の色が存在するかをチェックすることでグループ数を確認できます。
rng('default')
X = rand(20,2);
tree = linkage(X,'average');
dendrogram(tree,0,'ColorThreshold',0.4);
[H,T,outperm] = dendrogram(tree,0,'ColorThreshold',0.4);
lineColors = vertcat(H.Color); % Lineオブジェクトの色を行列に結合
uniqueColors = unique(lineColors, 'rows'); % ユニークな色(黒も合わせて出てきます)
size(uniqueColors,1) - 1 % 黒以外の色の数
  3 件のコメント
michio
michio 2018 年 7 月 17 日
上で得られたグループ数を使って
[H,T,outperm] = dendrogram(tree,4);
と実行すれば、少なくとも各グループの番号は取得できますがいかがでしょうか。
find(T==1)
denpika
denpika 2018 年 7 月 18 日
解決しました、ありがとうございました。

サインインしてコメントする。

その他の回答 (0 件)

カテゴリ

Help Center および File Exchangeクラスターの可視化と評価 についてさらに検索

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!