« 高周波・RFニュース 2026年2月3日 iFixitがApple AirTag2を分解、TechInsightsがSamsung Galaxy Z TriFoldを分解、ATDIがHuggingFaceに無線信号同定用AIモデルを公開、Rohde&Schwarzが新しい44GHzスペアナを発表、Cohere Tech.の6Gに向けたOTFS記事など | トップページ | 高周波・RFニュース 2026年2月4日 Pythonの高周波ライブラリscikit-rfがv1.10.0に、Airbus UpNextの5G NTN SpaceRAN、DellとAMDの通信会社とAIウェビナー、Mini-Circuitsの26GHzローパスフィルタ »

2026年2月 3日 (火)

高周波エンジニアのためのAI・機械学習入門(GPU編8)Pythonのパッチアンテナ設計モジュールを使ってパッチ寸法(幅、長さ)、基板厚み、共振周波数を与えて比誘電率をKeras3.0を用いたディープラーニング(DNN)による回帰で予測する。これもLayerNormalizationがよかった。

今回はこれのGPU編。

 高周波エンジニアのためのAI・機械学習入門(17)パッチアンテナ設計モジュールをPythonで作ったので、パッチ寸法(幅、長さ)、基板厚み、共振周波数を与えて比誘電率をKeras3.0を用いたディープラーニング(DNN)による回帰で予測する。

前回、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("patchantenna.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層を4層にしたDNNを設定
hidden_dim = 200
inputs = keras.Input(shape=(4,))
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)
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 = ["er"]
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(0, maxvalue)
ax[0].set_ylim(0, 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()

GPU使うと見てる間に計算が終わってストレスないな。

結果はこちら。

Gpudnnantenna_er

これも前回CPU版よりずっと精度が向上している。

 

 

« 高周波・RFニュース 2026年2月3日 iFixitがApple AirTag2を分解、TechInsightsがSamsung Galaxy Z TriFoldを分解、ATDIがHuggingFaceに無線信号同定用AIモデルを公開、Rohde&Schwarzが新しい44GHzスペアナを発表、Cohere Tech.の6Gに向けたOTFS記事など | トップページ | 高周波・RFニュース 2026年2月4日 Pythonの高周波ライブラリscikit-rfがv1.10.0に、Airbus UpNextの5G NTN SpaceRAN、DellとAMDの通信会社とAIウェビナー、Mini-Circuitsの26GHzローパスフィルタ »

パソコン・インターネット」カテゴリの記事

学問・資格」カテゴリの記事

日記・コラム・つぶやき」カテゴリの記事

コメント

コメントを書く

(ウェブ上には掲載しません)

« 高周波・RFニュース 2026年2月3日 iFixitがApple AirTag2を分解、TechInsightsがSamsung Galaxy Z TriFoldを分解、ATDIがHuggingFaceに無線信号同定用AIモデルを公開、Rohde&Schwarzが新しい44GHzスペアナを発表、Cohere Tech.の6Gに向けたOTFS記事など | トップページ | 高周波・RFニュース 2026年2月4日 Pythonの高周波ライブラリscikit-rfがv1.10.0に、Airbus UpNextの5G NTN SpaceRAN、DellとAMDの通信会社とAIウェビナー、Mini-Circuitsの26GHzローパスフィルタ »

最近の記事

2026年2月
1 2 3 4 5 6 7
8 9 10 11 12 13 14
15 16 17 18 19 20 21
22 23 24 25 26 27 28

最近のコメント

無料ブログはココログ
フォト