« RF Weekly Digest (Gemini 3.1 Pro・Google AI Studio BuildによるAIで高周波・RF情報の週刊まとめアプリ)2026/5/3-5/10 | トップページ | 高周波・RFニュース 2026年5月12日 IEEE Microwave Magazineはモデリングと最適化特集、Journal of Microwavesも5月号発行、iFixitがHuawei Pura X Maxを分解、TDKがSensorGPTを開発、Mini-CircuitsのLNA MMIC解説動画など »

2026年5月11日 (月)

高周波エンジニアのためのAI・機械学習入門(GPU編22)TDRでは出せない複素特性インピーダンスの周波数特性を予測する。今回はkerasとバックエンドにJaxを使ったCNNで。

さて前回はDNNを使って予測した。今回は畳み込みニューラルネットワークCNNでやってみよう。

コードはこちら。


import numpy as np
import matplotlib.pyplot as plt
from sklearn.model_selection import train_test_split
from sklearn.preprocessing import StandardScaler
import os
os.environ["KERAS_BACKEND"] = "jax"
import keras
from jax import config
config.update("jax_enable_x64", False)
plt.rcParams['font.family'] = 'Noto Sans CJK JP'

data_label = np.load("tl_freq_data.npz")
data = data_label["data"].reshape(-1,200,5,1)
label = data_label["label"]
x_train, x_test, y_train, y_test = train_test_split(data, label, test_size=0.3, random_state=0)
y_train_list = [y_train[:,:,1], y_train[:,:,2]]
y_test_list = [y_test[:,:,1], y_test[:,:,2]]

scaler_y = [StandardScaler() for _ in range(2)]
y_train_list_f = [None for _ in range(2)]
for i in range(2):
    scaler_y[i] = StandardScaler()
    y_train_list_f[i] = scaler_y[i].fit_transform(y_train_list[i])


inputs = keras.Input(shape=(200, 5, 1))
x = keras.layers.Conv2D(64, kernel_size=(10, 2), activation="relu")(inputs)
x = keras.layers.Conv2D(64, kernel_size=(10, 4), activation="relu")(x)
x = keras.layers.Flatten()(x)
outputs = [keras.layers.Dense(200)(x) for i in range(2)]

model = keras.Model(inputs=inputs, outputs=outputs)
model.compile(loss = 'mean_squared_error' ,optimizer=keras.optimizers.Adam())

batch_size = 64
epochs = 1000
keras.utils.set_random_seed(1)
history = model.fit(
    x_train,
    y_train_list_f,
    batch_size=batch_size,
    epochs=epochs,
    validation_split=0.15,
)

y_pred_list_f = model.predict(x_test)
y_pred_list = [None for _ in range(2)]
for i in range(2):
    y_pred_list[i] = scaler_y[i].inverse_transform(y_pred_list_f[i])

metric = keras.metrics.R2Score()
for idx in range(2):
    print(f"R2 score for label {idx}:")
    metric.update_state(y_test_list[idx], y_pred_list[idx])
    result = metric.result()
    print(result)


R2スコアは

R2 score for label 0:
0.9999931
R2 score for label 1:
0.9999989

とDNNよりさらによくなった。

代表例はこちら。

 

Gpuz0freqcnn01

誤差の最大値をヒストグラムにしたもの。

Gpuz0freqcnn02

精度はかなりよく、実用性があるのでは。

 

 

 

 

« RF Weekly Digest (Gemini 3.1 Pro・Google AI Studio BuildによるAIで高周波・RF情報の週刊まとめアプリ)2026/5/3-5/10 | トップページ | 高周波・RFニュース 2026年5月12日 IEEE Microwave Magazineはモデリングと最適化特集、Journal of Microwavesも5月号発行、iFixitがHuawei Pura X Maxを分解、TDKがSensorGPTを開発、Mini-CircuitsのLNA MMIC解説動画など »

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

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

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

コメント

コメントを書く

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

« RF Weekly Digest (Gemini 3.1 Pro・Google AI Studio BuildによるAIで高周波・RF情報の週刊まとめアプリ)2026/5/3-5/10 | トップページ | 高周波・RFニュース 2026年5月12日 IEEE Microwave Magazineはモデリングと最適化特集、Journal of Microwavesも5月号発行、iFixitがHuawei Pura X Maxを分解、TDKがSensorGPTを開発、Mini-CircuitsのLNA MMIC解説動画など »

最近の記事

2026年6月
  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 29 30        

最近のコメント

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