質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

Q&A

解決済

1回答

3129閲覧

閾値を指定した階層型クラスタリングの方法について

kuromi

総合スコア6

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

0グッド

0クリップ

投稿2021/07/02 10:00

閾値をしていてクラスタリング結果を得たい

Cosine類似度を用いてWard法と最長距離法で、
閾値を変更させて変化するクラスタリングの結果が得たいです。

発生している問題・エラーメッセージ

Method 'ward' requires the distance metric to be Euclidean

該当のソースコード

python

1 2z = linkage(df, metric='cosine', method='ward') 3 4fig = plt.figure(figsize=(12, 6)) 5ax = fig.add_subplot(1, 1, 1, title="樹形図") 6dendrogram(z) 7plt.show() 8 9clusters1 = fcluster(z, 0.05, criterion='distance') 10for i, c in enumerate(clusters1): 11 print(i, c) 12

試したこと

import linkage
ではユークリッド距離でしかWard法が使えないらしい。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

linkageには手元のデータを投入して距離計算とともにdendrogramに必要は結果を出力する方法と距離計算を別に行っておいてその結果を入力してdendrogramに必要な結果を出力する方法のふたつが実装されています。よって、別にCosine類似度を計算しておいてlinkage関数に入力する実装をすれば期待した結果を得ることができます。

python

1from scipy.spatial.distance import pdist ###距離計算の関数 2from scipy.cluster.hierarchy import linkage, dendrogram 3 4dist = pdist(df,metric='cosine') ### cosine類似度を距離に見立てて計算 5z = linkage(dist) 6dendrogram(z) 7plt.show() 8

pdist()ですが、公式ドキュメントを見るとわかりますが、いわゆるcosine類似度が結果として返ってくるわけではありません。1-cosine類似度が計算結果となります。これはこの後のlinkageに入力する値は距離である必要があり、距離の定義上、非負値である必要があるための操作です。

投稿2021/07/03 00:29

R.Shigemori

総合スコア3376

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問