高周波エンジニアのためのAI・機械学習入門(8)教師あり学習でバンドパスフィルタ(BPF)の中心周波数ずれのG/NG判定をPythonとKeras 3.0を使ってディープラーニング(DNN)で行う。
前回のフィルタの種類の分類は簡単すぎるのか精度100%になって面白くない。
そこでもうちょっと微妙な例としてバンドパスフィルタ(BPF)の中心周波数が微妙にずれてNGになることが判定できるかをやってみる。
10000個データとってもこんな感じで微妙なずれだが、90%が良品、10%が不良品のようなデータになっている。
入力はこのSパラメータで、出力はGが1、NGが0の二値になっている。
DNNのコードはこんな感じで、今までと違うのはロスがbinary crossentropyになっている。
import numpy as np
import matplotlib.pyplot as plt
from sklearn.model_selection import train_test_split
import os
os.environ["KERAS_BACKEND"] = "tensorflow"
import keras
data_label = np.load("G_NG.npz")
data = data_label["data"]
label = data_label["label"]
x_train, x_test, y_train, y_test = train_test_split(data, label, test_size=0.3, random_state=0)
# Functional APIでDense層+ドロップアウト層(今回使わず)を3層にしたDNNを設定
hidden_dim = 200
inputs = keras.Input(shape=(200, 5))
x = keras.layers.Flatten()(inputs)
x = keras.layers.Dense(hidden_dim, activation="relu")(x)
#x = keras.layers.Dropout(0.5)(x)
x = keras.layers.Dense(hidden_dim, activation="relu")(x)
#x = keras.layers.Dropout(0.5)(x)
x = keras.layers.Dense(hidden_dim, activation="relu")(x)
#x = keras.layers.Dropout(0.5)(x)
outputs = keras.layers.Dense(1, activation="sigmoid")(x)
# モデルの設定
model = keras.Model(inputs=inputs, outputs=outputs)
model.compile(optimizer=keras.optimizers.Adam(), loss=keras.losses.BinaryCrossentropy(),
metrics=[keras.metrics.BinaryAccuracy(),])
batch_size = 32
epochs = 100
keras.utils.set_random_seed(1)
model.fit(
x_train,
y_train,
batch_size=batch_size,
epochs=epochs,
validation_split=0.15,
)
score = model.evaluate(x_test, y_test, verbose=0)
print(f"Test Score{score}")
|
結果はこちら。97%強の精度。まあまあだがこれでは実際には使えないなあ。次はCNNで改善できないか見てみる。
« 高周波・RFニュース 2024年8月22日 Samsung Galaxy RingをiFixitが分解、ネットアナのキャリブレーションの本が出版へ、ワカ製作所の1㎜同軸コネクタ、ロームのSOPパッケージAC-DCコントローラIC | トップページ | 映画「ラストマイル」を観てきた。面白かった!最後の爆弾の伏線に痺れた。タイトル回収シーンやミスリーディングを誘う展開、巨大なロジスティクスセンター、リアルな爆発。アンナチュラル、MIU404メンバーも重要な役割。特捜最前線のある話を思い出すシーンも。 »
「パソコン・インターネット」カテゴリの記事
- PythonでFDTD法で電磁界シミュレーションできるopenEMSを使う(1)例題にあるマイクロストリップラインのノッチフィルタ(スタブ)を動かして電磁界分布を動画で見てみる。CSXCADでモデルは確認できるし、ParaViewで電磁界分布が見られる。Sパラメータも計算できる。(2025.05.14)
- ユニクロとAkamaiのコラボTシャツに書かれているコードを解読してみる。base64でデコードするとbashのシェルスクリプトが出てきて実行すると♥PEACE♥FOR♥ALL♥FOR♥ALL♥PEACE♥FOR♥ALL♥という文字が色付きで正弦波で流れた。(2025.05.01)
- Google Gemini 2.5 Pro experimentalに高周波で使われるSパラメータのTouchstoneファイルを読み込んでプロットするC#コードを書いてもらうと570行のコードができて動いた。ファイルの拡張子snpのnでポート数を判別するが人間を信じないのでデータ数えて確認するのに笑った。(2025.04.21)
「学問・資格」カテゴリの記事
- 高周波・RFニュース 2025年5月16日 BAWフィルタのAkoustisがSpace Xの子会社に売却へ、DuPontがPyraluxなどのエレクトロニクス部門をスピンオフさせQnityという名前に、Microwave Journal5月号でローデ・シュワルツが最新スペアナ解説、GSAが5G Advancedレポート発行(2025.05.16)
- 高周波・RFニュース 2025年5月15日 2025 104th ARFTG のプロシーディング公開、R&SがRF Testing Innovations Forum開催、IEEE Journal of Microwaves5月号発行、Microwave Journal5月特別号は宇宙特集、QorvoがMatter用SoC 3種発売、MediaTekが5G FWA用T930発売(2025.05.15)
- 高周波・RFニュース 2025年5月14日 TDKが8A流せる積層チップビーズを発表、Samsungが5.8㎜の薄さのGalaxy 25 Edge発表、InfineonがマルチセンステクノロジーのPSOC 4100T Plus発表、u-bloxがPointPerfect Global発表、下院委員会が3GHzと6GHzをオークションから除外(2025.05.14)
「日記・コラム・つぶやき」カテゴリの記事
- 高周波・RFニュース 2025年5月16日 BAWフィルタのAkoustisがSpace Xの子会社に売却へ、DuPontがPyraluxなどのエレクトロニクス部門をスピンオフさせQnityという名前に、Microwave Journal5月号でローデ・シュワルツが最新スペアナ解説、GSAが5G Advancedレポート発行(2025.05.16)
- 高周波・RFニュース 2025年5月15日 2025 104th ARFTG のプロシーディング公開、R&SがRF Testing Innovations Forum開催、IEEE Journal of Microwaves5月号発行、Microwave Journal5月特別号は宇宙特集、QorvoがMatter用SoC 3種発売、MediaTekが5G FWA用T930発売(2025.05.15)
- 高周波・RFニュース 2025年5月14日 TDKが8A流せる積層チップビーズを発表、Samsungが5.8㎜の薄さのGalaxy 25 Edge発表、InfineonがマルチセンステクノロジーのPSOC 4100T Plus発表、u-bloxがPointPerfect Global発表、下院委員会が3GHzと6GHzをオークションから除外(2025.05.14)
« 高周波・RFニュース 2024年8月22日 Samsung Galaxy RingをiFixitが分解、ネットアナのキャリブレーションの本が出版へ、ワカ製作所の1㎜同軸コネクタ、ロームのSOPパッケージAC-DCコントローラIC | トップページ | 映画「ラストマイル」を観てきた。面白かった!最後の爆弾の伏線に痺れた。タイトル回収シーンやミスリーディングを誘う展開、巨大なロジスティクスセンター、リアルな爆発。アンナチュラル、MIU404メンバーも重要な役割。特捜最前線のある話を思い出すシーンも。 »
コメント