高周波エンジニアのためのAI・機械学習入門(GPU編9)パッチアンテナ設計モジュールをPythonで作ったので、電気的に測定できる入力インピーダンス、共振周波数を与えて指向性(Directivity)をKeras3.0を用いたディープラーニング(DNN)による回帰で予測する。
今回はこれのGPU版。
前回と同様にLayerNormalizationを入れて、かつ出力もスケーリングしておく。
コードはこちら。
import os
os.environ["KERAS_BACKEND"] = "jax"
import keras
import numpy as np
import matplotlib.pyplot as plt
from sklearn.model_selection import train_test_split
from sklearn.preprocessing import StandardScaler
plt.rcParams['font.family'] = 'Noto Sans CJK JP'
from jax import config
config.update("jax_enable_x64", False)
data_label = np.load("directivity.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)
#正規化
normalizer = keras.layers.Normalization()
normalizer.adapt(x_train)
scaler_y = StandardScaler()
y_train_f = scaler_y.fit_transform(y_train)
y_test_f = scaler_y.transform(y_test)
# Functional APIでDense層を5層にしたDNNを設定
hidden_dim = 200
inputs = keras.Input(shape=(2,))
x = normalizer(inputs)
x = keras.layers.Dense(hidden_dim, activation="relu")(x)
x = keras.layers.LayerNormalization(epsilon=1.0e-6)(x)
x = keras.layers.Dense(hidden_dim, activation="relu")(x)
x = keras.layers.LayerNormalization(epsilon=1.0e-6)(x)
x = keras.layers.Dense(hidden_dim, activation="relu")(x)
x = keras.layers.LayerNormalization(epsilon=1.0e-6)(x)
x = keras.layers.Dense(hidden_dim, activation="relu")(x)
x = keras.layers.LayerNormalization(epsilon=1.0e-6)(x)
x = keras.layers.Dense(hidden_dim, activation="relu")(x)
x = keras.layers.LayerNormalization(epsilon=1.0e-6)(x)
outputs = keras.layers.Dense(1)(x)
# モデルの設定
model = keras.Model(inputs=inputs, outputs=outputs)
model.compile(loss = 'mean_squared_error' ,optimizer=keras.optimizers.Adam())
batch_size = 128
epochs = 1000
keras.utils.set_random_seed(1)
history = model.fit(
x_train,
y_train_f,
batch_size=batch_size,
epochs=epochs,
validation_split=0.15,
)
y_pred_f = model.predict(x_test)
y_pred = scaler_y.inverse_transform(y_pred_f)
metric = keras.metrics.R2Score()
metric.update_state(y_test, y_pred)
result = metric.result()
print(result)
error = np.abs((y_test - y_pred)/y_test*100)
print(error.mean(axis=0))
legend = ["Directivity"]
fig, ax = plt.subplots(1, 2, figsize=(12,6))
maxvalue = y_pred.max()
ax[0].scatter(y_pred, y_test, c="r", s=5)
ax[0].plot([0,maxvalue], [0,maxvalue], "--", c="black")
ax[0].set_xlabel("推定した値")
ax[0].set_ylabel("実際の値")
ax[0].set_xlim(5, maxvalue)
ax[0].set_ylim(5, maxvalue)
ax[0].grid()
ax[0].legend([legend[0] + f" 平均誤差{error.mean():.2f}%"])
ax[1].hist(error, bins = 100)
ax[1].set_xlabel("誤差[%]")
ax[1].set_ylabel("頻度")
ax[1].grid()
fig.tight_layout()
plt.show()
|
結果はこちら。
うーん、CPU版と比べてそんなに改善されてる感じではないな。もともとそんなに精度が悪くないので仕方ないか。
« 高周波・RFニュース 2026年2月5日 BroadcomがエンタープライスWi-Fi 8アクセスポイントとスイッチ発表、Vishayが民生と車載向けパワーインダクタ発表、ABI Researchの6Gスペクトラムレポート、Mini-CircuitsのMMIC LNAアプリケーションノートなど | トップページ | 高周波・RFニュース 2025年2月6日 Texas InstrumentsがSilicon Labsを買収、JDIとKymetaが衛星通信用アンテナガラス基板の共同開発、Emersonの計測に特化したNI Nigel AI、TDKが200A垂直給電用μPOLモジュール量産、ATISがOpen Access Network Forum発足 »
「パソコン・インターネット」カテゴリの記事
- RF Weekly Digest (Codexで作ったOllama経由のgemma4-26B-A4B QAT、DuckDuckGo Searchを使った高周波・RF情報の週刊まとめアプリ)2026/6/7-6/14(2026.06.14)
- ゼロから作るDeep Learning 6 LLM編を買った。めちゃくちゃわかりやすい。事後学習がこんなに重要とは知らなかった。KVキャッシュって何やってるか等も。Interface誌の7月号特集が作りながら学ぶTransformer/LLMなので一緒に読みながらだとより理解が深まる。(2026.06.11)
- Gemma 4 QATがOllama経由で使えるようになっていた。そこで今度はGoogle Antigravity(Gemini 3.5 Flash)にローカルLLMでRF情報一週間分まとめて日本語で要約するアプリ(gemma4-26B-A4B QAT、DuckDuckGo Search、Flask使用)を作ってもらう。画面デザインはこっちがいいな。(2026.06.15)
- Gemma 4 QATがOllama経由で使えるようになっていた。そこでCodex(GPT-5.5)に、これまでいまいちだったローカルLLMでRF情報一週間分まとめて日本語で要約するアプリ(gemma4-26B-A4B QAT、DuckDuckGo Search、Flask使用)を作ってもらうと相当いい出来で使えそう。(2026.06.10)
- RF Weekly Digest (Gemini 3.5 Flash・Google AI Studio BuildによるAIで高周波・RF情報の週刊まとめアプリ)2026/5/31-6/7(2026.06.07)
「学問・資格」カテゴリの記事
- 高周波・RFニュース 2026年6月17日 Ericsson Mobility Report June 2026発行・5G契約数は31億件、3GPPが最初の6G-RAN研究承認、Nordicが忘れ物タグのプロトタイプを発表、アンリツがソフトウェア無線ソリューション発表など(2026.06.17)
- 高周波・RFニュース 2026年6月16日 Microwave JournalにアンリツのTensor VNA解説記事、6G Worldで6GのRF設計の重要さ解説記事、3GPPのシンガポール総会の様子、GSAがプライベートモバイルネットワーク調査など(2026.06.16)
- RF Weekly Digest (Codexで作ったOllama経由のgemma4-26B-A4B QAT、DuckDuckGo Searchを使った高周波・RF情報の週刊まとめアプリ)2026/6/7-6/14(2026.06.14)
- FIFAワールドカップ2026で使われているボールTriondaにはカタールの時と同様にKinexonのUWBモジュール(ICはQorvo)と慣性センサが入っているが、カタールが中央につるされて入っている感じなのがボールの裏側に貼りつくかたちで入るようになった。FCCでチェック。(2026.06.14)
- 高周波・RFニュース 2026年6月12日 アンリツがAI対応のTensor VNA発表、Qualcommが5G NR NTN解説、iFixitがTrump phoneを分解・やっぱりHTC U24 Proとほぼ同じ、6G Worldの3GPPミーティング解説記事など(2026.06.12)
「日記・コラム・つぶやき」カテゴリの記事
- 高周波・RFニュース 2026年6月17日 Ericsson Mobility Report June 2026発行・5G契約数は31億件、3GPPが最初の6G-RAN研究承認、Nordicが忘れ物タグのプロトタイプを発表、アンリツがソフトウェア無線ソリューション発表など(2026.06.17)
- 高周波・RFニュース 2026年6月16日 Microwave JournalにアンリツのTensor VNA解説記事、6G Worldで6GのRF設計の重要さ解説記事、3GPPのシンガポール総会の様子、GSAがプライベートモバイルネットワーク調査など(2026.06.16)
- RF Weekly Digest (Codexで作ったOllama経由のgemma4-26B-A4B QAT、DuckDuckGo Searchを使った高周波・RF情報の週刊まとめアプリ)2026/6/7-6/14(2026.06.14)
- 高周波・RFニュース 2026年6月12日 アンリツがAI対応のTensor VNA発表、Qualcommが5G NR NTN解説、iFixitがTrump phoneを分解・やっぱりHTC U24 Proとほぼ同じ、6G Worldの3GPPミーティング解説記事など(2026.06.12)
- 高周波・RFニュース 2026年6月11日 QorvoがXバンドレーダ用フロントエンドモジュール発表、3GPPがRel.21のタイムライン発表、NI(Emerson)が雑音指数測定のウェビナー開催、MIPI A-PHYのSerDesが4社で相互運用性確認、Menlo Microが高信頼性ミリ波スイッチ発表など(2026.06.11)
« 高周波・RFニュース 2026年2月5日 BroadcomがエンタープライスWi-Fi 8アクセスポイントとスイッチ発表、Vishayが民生と車載向けパワーインダクタ発表、ABI Researchの6Gスペクトラムレポート、Mini-CircuitsのMMIC LNAアプリケーションノートなど | トップページ | 高周波・RFニュース 2025年2月6日 Texas InstrumentsがSilicon Labsを買収、JDIとKymetaが衛星通信用アンテナガラス基板の共同開発、Emersonの計測に特化したNI Nigel AI、TDKが200A垂直給電用μPOLモジュール量産、ATISがOpen Access Network Forum発足 »



コメント