高周波エンジニアのためのAI・機械学習入門(GPU編24)TDRでは出せない複素特性インピーダンスの周波数特性を予測する。今回はkerasとバックエンドにJaxを使ったTransformerで。
DNN,CNN,RNN(LSTM)とやってきて今回はTransformer。
コードはこちら。
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"]
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])
# ==========================
# Positional Encoding
# ==========================
def positional_encoding(seq_len, d_model):
pos = np.arange(seq_len)[:, np.newaxis]
i = np.arange(d_model)[np.newaxis, :]
angle_rates = 1 / np.power(10000, (2 * (i // 2)) / np.float32(d_model))
angle_rads = pos * angle_rates
pe = np.zeros((seq_len, d_model))
pe[:, 0::2] = np.sin(angle_rads[:, 0::2])
pe[:, 1::2] = np.cos(angle_rads[:, 1::2])
return keras.ops.convert_to_tensor(pe, dtype="float32")
# ==========================
# Transformer Encoder Block
# ==========================
def transformer_encoder(x, head_size, num_heads, ff_dim, dropout=0.1):
# Self Attention
attn_out = keras.layers.MultiHeadAttention(
num_heads=num_heads,
key_dim=head_size
)(x, x)
#attn_out = keras.layers.Dropout(dropout)(attn_out)
x = keras.layers.LayerNormalization(epsilon=1e-6)(x + attn_out)
# Feed Forwardネットワーク
ffn = keras.layers.Dense(ff_dim, activation="relu")(x)
ffn = keras.layers.Dense(x.shape[-1])(ffn)
#ffn = keras.layers.Dropout(dropout)(ffn)
x = keras.layers.LayerNormalization(epsilon=1e-6)(x + ffn)
return x
seq_len = 200
feat_dim = 5
embed_dim = 64
inputs = keras.Input(shape=(seq_len, feat_dim))
# 入力を高次元に射影
x = keras.layers.Dense(embed_dim)(inputs)
# Positional Encodingを加算
pe = positional_encoding(seq_len, embed_dim)
x = x + pe
# Transformer ブロック
x = transformer_encoder(x, head_size=64, num_heads=4, ff_dim=128)
#x = transformer_encoder(x, head_size=64, num_heads=4, ff_dim=128)
# 時系列次元を集約
x = keras.layers.GlobalAveragePooling1D()(x)
# 全結合
x = keras.layers.Dense(128, activation="relu")(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 = 128
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.99998623
R2 score for label 1:
0.9999977
代表例。ちょっとずれてるか。
最大誤差をヒストグラムにしたもの。
そこそこいいが、今回の例ではCNNが一番精度、速度ともによさそう。
« 高周波・RFニュース 2026年5月22日 6GWorldとKeysightのRFデジタルツイン解説とウェビナー、Qualcomm がDragonwing Mobile Broadband Multimedia (MBM)発表、Sony Xperia 1 VII分解動画、SiLabのSoCを使ったComminentのWi-SUNモジュールが500,000台出荷など | トップページ | スター・ウォーズ/マンダロリアン・アンド・グローグーをIMAXで観てきた。面白かった!パペットで動くグローグーがかわいく、隙あらば何でも食べようとし、人では相手にならないマンドーはいろんなものと戦うし、最後はスターウォーズのお約束とオマージュシーンでよかった。 »
「パソコン・インターネット」カテゴリの記事
- 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年5月22日 6GWorldとKeysightのRFデジタルツイン解説とウェビナー、Qualcomm がDragonwing Mobile Broadband Multimedia (MBM)発表、Sony Xperia 1 VII分解動画、SiLabのSoCを使ったComminentのWi-SUNモジュールが500,000台出荷など | トップページ | スター・ウォーズ/マンダロリアン・アンド・グローグーをIMAXで観てきた。面白かった!パペットで動くグローグーがかわいく、隙あらば何でも食べようとし、人では相手にならないマンドーはいろんなものと戦うし、最後はスターウォーズのお約束とオマージュシーンでよかった。 »




コメント