高周波エンジニアのためのAI・機械学習入門(14)因子分析(FactorAnalysis、教師なし学習)でバンドパスフィルタ(BPF)の次数が異なるもの(減衰がちがうもの)を2軸で特徴付けできるかPythonとscikit-learnでやってみる。主成分分析(PCA)より綺麗に分かれた。
前回は主成分分析を行ったが、今回は因子分析。
因子分析のメリットや結果の見方を具体例から解説
前回と同じく、次数が違うバンドパスフィルタを解析してみる。
因子分析もscikit-learnで簡単にできる。
https://scikit-learn.org/stable/modules/generated/sklearn.decomposition.FactorAnalysis.html
コードはこんな感じ。
|
import numpy as np
import matplotlib.pyplot as plt
from sklearn.preprocessing import StandardScaler
from sklearn.decomposition import FactorAnalysis
data_label = np.load("filter_PCA.npz")
data = data_label["data"]
label = data_label["label"]
data = 10*np.log10(data[:, :, 3]**2 + data[:, :, 4]**2)
scaler = StandardScaler()
scaler.fit(data)
X_scaled = scaler.transform(data)
fa = FactorAnalysis(2, max_iter=5000)
X_FA= fa.fit_transform(X_scaled)
fig = plt.figure(figsize=(12,12))
plt.scatter(X_FA[np.argwhere(label==3)[:,0],0], X_FA[np.argwhere(label==3)[:,0],1], c="r", label="3rd")
plt.scatter(X_FA[np.argwhere(label==5)[:,0],0], X_FA[np.argwhere(label==5)[:,0],1], c="g", label="5th")
plt.scatter(X_FA[np.argwhere(label==7)[:,0],0], X_FA[np.argwhere(label==7)[:,0],1], c="b", label="7th")
plt.legend()
plt.grid()
plt.xlabel("PC1")
plt.ylabel("PC2")
|
結果:
おお、PCAよりきれいに分離している。
コンポーネントの係数はだいたい似てる。
« 「黒牢城」(米澤穂信さん)をようやく読んだ。すごかった。黒田官兵衛が荒木村重に有岡城に幽閉されていた史実をベースに、その官兵衛が安楽椅子探偵のように城内で起こる怪事件を解決していくミステリ。そして驚愕の真相が立て続けに。ラストは史実に基づくけど本当によかった。 | トップページ | 高周波エンジニアのためのAI・機械学習入門(15)独立成分分析(ICA、教師なし学習)でバンドパスフィルタ(BPF)の次数が異なるもの(減衰がちがうもの)を2軸で特徴付けできるかPythonとscikit-learnでやってみる。 »
「パソコン・インターネット」カテゴリの記事
- ExcelのOfficeスクリプト(TypeScript)で数値計算ライブラリmath.jsを使う(2) FFT(高速フーリエ変換)を実行する。getValues, setValuesで2次元と1次元の配列の相互変換が必要。(2026.04.23)
- RF Weekly Digest (Gemini 3.1 Pro・Google AI Studio BuildによるAIで高周波・RF情報の週刊まとめアプリ)2026/4/12-4/19(2026.04.19)
- Qwen3.6-35B-A3Bが発表され、Ollamaでも使える。そこで電子レンジの動作原理(2.45GHzは水分子の共振周波数でない)と隕石が大気圏突入で燃える原理(摩擦熱ではない)を聞くと、誘電緩和と断熱圧縮について正しく答えられた。今までのローカルLLMで一番賢い回答と思う。(2026.04.17)
- ExcelのOfficeスクリプト(TypeScript)で数値計算ライブラリmath.jsを使う(1) Officeスクリプトは外部API呼び出せるし、math.jsは RESTful APIで呼び出せることがわかった。まずは選択したセルのデータを読み、行列演算。LU分解で一次方程式を解き、逆行列と行列式を求める。(2026.04.17)
- RF Weekly Digest (Gemini 3.1 Pro・Google AI Studio BuildによるAIで高周波・RF情報の週刊まとめアプリ)2026/4/5-4/12(2026.04.12)
「学問・資格」カテゴリの記事
- 高周波・RFニュース 2026年4月23日 Qualcommへの6G周波数割り当てインタビュー動画、5Gミリ波向け基板材料・技術のレビュー論文発行、車内センシングレーダ解説、Amphenol RFの18GHzまで使えるSMAピッグテイルアセンブリ(2026.04.23)
- 高周波・RFニュース 2026年4月22日 QualcommのAIネイティブ6Gインタビュー動画、LGイノテックが車載Wi-Fi7モジュール1,000億ウォン受注、GSAが無線市場の現状をレポート、AppleのCEOがTim CookからJohn Ternusへ、など(2026.04.22)
- ExcelのOfficeスクリプト(TypeScript)で数値計算ライブラリmath.jsを使う(2) FFT(高速フーリエ変換)を実行する。getValues, setValuesで2次元と1次元の配列の相互変換が必要。(2026.04.23)
- 高周波・RFニュース 2026年4月21日 Qorvoが電子戦でのワイドバンドRF解説、SkyworksがIC-MAMでSAW・BAW技術を複数発表、6G WorldとKeysightが6G PHYについて解説とウェビナー開催、Analog DevicesがMEMS SP4T発表など(2026.04.21)
- RF Weekly Digest (Gemini 3.1 Pro・Google AI Studio BuildによるAIで高周波・RF情報の週刊まとめアプリ)2026/4/12-4/19(2026.04.19)
「日記・コラム・つぶやき」カテゴリの記事
- 高周波・RFニュース 2026年4月23日 Qualcommへの6G周波数割り当てインタビュー動画、5Gミリ波向け基板材料・技術のレビュー論文発行、車内センシングレーダ解説、Amphenol RFの18GHzまで使えるSMAピッグテイルアセンブリ(2026.04.23)
- 高周波・RFニュース 2026年4月22日 QualcommのAIネイティブ6Gインタビュー動画、LGイノテックが車載Wi-Fi7モジュール1,000億ウォン受注、GSAが無線市場の現状をレポート、AppleのCEOがTim CookからJohn Ternusへ、など(2026.04.22)
- ExcelのOfficeスクリプト(TypeScript)で数値計算ライブラリmath.jsを使う(2) FFT(高速フーリエ変換)を実行する。getValues, setValuesで2次元と1次元の配列の相互変換が必要。(2026.04.23)
- 高周波・RFニュース 2026年4月21日 Qorvoが電子戦でのワイドバンドRF解説、SkyworksがIC-MAMでSAW・BAW技術を複数発表、6G WorldとKeysightが6G PHYについて解説とウェビナー開催、Analog DevicesがMEMS SP4T発表など(2026.04.21)
- RF Weekly Digest (Gemini 3.1 Pro・Google AI Studio BuildによるAIで高周波・RF情報の週刊まとめアプリ)2026/4/12-4/19(2026.04.19)
« 「黒牢城」(米澤穂信さん)をようやく読んだ。すごかった。黒田官兵衛が荒木村重に有岡城に幽閉されていた史実をベースに、その官兵衛が安楽椅子探偵のように城内で起こる怪事件を解決していくミステリ。そして驚愕の真相が立て続けに。ラストは史実に基づくけど本当によかった。 | トップページ | 高周波エンジニアのためのAI・機械学習入門(15)独立成分分析(ICA、教師なし学習)でバンドパスフィルタ(BPF)の次数が異なるもの(減衰がちがうもの)を2軸で特徴付けできるかPythonとscikit-learnでやってみる。 »





コメント