# MISH TECH JOURNAL(ミッシュ・テックジャーナル)は、最新の情報をいち早くお届けする技術情報誌です。

2025

mmer

Powered by

# MISH



https://www.mish.co.jp

# CONTENTS

AWGを使用したマルチトーン信号生成 — P.2-13 はじめに 従来のAWGモード DDSモード マルチトーン信号生成 疑似コードの利用 固有周波数と振幅の傾斜 位相の挙動 カスタム周波数スロープ DDSコマンドを使用した XIO ラインの制御 ソフトウェア駆動のフィードバックループ / 意思決定 継続的なストリーミング Execute-Now を使用したシングルステッププログラミング まとめ

# AWGでダイレクトデジタル合成 (DDS)を使用する利点 - P.14-19

はじめに DDS オプション 正弦波出力のプログラミング デュアルトーン波形 マルチトーン波形 マルチトーンマルチ出力アプリケーション 直交変調 まとめ

2枚のデジタイザを使用して20GSPSを実現する方法 - P.20-23

はじめに アプリケーション データストリーミング ハードウェアの詳細 2 枚の ADQ35 デジタイザへの信号入力 ソフトウェアの詳細 サンプルコード 追加の測定機器 結果

分散型光ファイバーセンシング (DFOS) - P.24-25 はじめに 分散型光ファイバーセンシング (DFOS) の基礎 デジタイザを選択する際に考慮すべき事項

### 新製品ピックアップ P.26-27 SPECTRUM 社製 M5i.6357-x16 10GSPS 高速 D/A ボード Alpha Data 社製 ADM-XRC-9R1-B RFSoC 搭載 FPGA ボード Teledyne SP Devices 社製 ADQ35-WB 10GSPS 広帯域 A/D ボード Dagscribe 社製 DDR7400 400Gbps イーサネットデータレコーダ Dagscribe 社製 RDR4050 MIL 規格対応 耐環境イーサネットレコーダ

# <sup>25夏号特集</sup> Direct Digital Synthesizer AWGを使用したマルチトーン信号生成

企画・編集・発行/株式会社ミッシュインターナショナル 〒190-0004 東京都立川市柏町4-56-1 グローバルビル TEL:042-538-7650 Email:sales@mish.co.jp Copyright © 2025 MISH International

# SPECIAL FEATURE





# はじめに

ここではSpectrum Instrumentation製 AWGボードを使用したマルチトーン信 号の生成について詳しく説明します。

DDS は、Direct Digital Synthesizer の略で複数のDDSコアを使用して複数 の異なる周波数の正弦波を生成するこ とができます。

# 従来のAWGモード

DDSモードのさまざまな側面を詳し く説明する前に、まず従来の任意波形 発生器 (AWG) モードを詳しく見てみま す。このモードでは、ユーザーは出力 波形を構成する各サンプルデータを事 前に作成し、それをオンボードメモリ に送信します。その後、このデータを 標準再生モード、FIFOモード、シーケ ンスモードなどの選択した再生モード に応じて、ワンショット、ループ再生、 または連続ストリームでアナログ出力 に再生できます。原則として、この AWGモードではあらゆる種類の出力波 形が可能なことから、多くのアプリケー ションで柔軟なソリューションになり ます。

高いサンプリング周波数で長いAWG データシーケンスを保存するには、大 容量のオンボードメモリが必要です。 そのため、たとえば最大サンプリング 周波数が1.25GHzのAWGカードの M4i.66xxシリーズには、4GByte (2Gサ ンプル)のメモリが搭載されています。 この大容量メモリにより、1秒を超える シーケンスを保存できます。

AWGカードに連続的なデータスト リームを転送するために、すべての Spectrum製AWGカードには高速PCle インターフェイスがあり、1秒あたり数 ギガバイトのデータを簡単に転送でき ます。CPUを使用して必要なAWGデー タを継続的に計算するのは非常に困難 なため、Spectrum 製カードはSCAPP オプションを使用して、NVIDIAの最先 端のCUDA GPUアクセラレータカード からの転送もサポートしています。

ストリーミングFIFOモードでは、オ ンボードメモリが送信データのFIFO バッファとして使用されます。これに より、データを生成するユーザーアプ リケーションが一瞬停止するイベント を補正できるため、ストリーミングの 信頼性が非常に高くなります。ただし、

バッファリングによって遅延も発生 するため、クローズドフィードバック ループや一般的な制御システムなどの 特定のアプリケーションでは不利にな る場合があります。

応答時間を短縮し、データ転送を削 減するために、AWGにはシーケンス モードがあります。このモードでは、 事前に保存されたさまざまなシーケン スを構成可能な順序でループし、外部 トリガー入力でシーケンス間の切り替 えをトリガーできます。

ただし、シーケンスモードでは依然 として小さなFIFOバッファが使用され ます。したがって、外部入力でシーケ ンスの変更をトリガーする場合、FIFO バッファ内の古いデータを出力に転送 する必要があり、FIFOバッファ内の古 いデータの量が変化すると、この特定 のモードとアプリケーションでの動的 動作に不確実性が生じる可能性もあり ます。

# DDSモード

正弦波信号のみが必要な場合はDDS モードを使用できます。ダイレクトデ ジタル合成(DDS)を使用すると、必要 な周波数 *fi*、振幅 *Ai*、初期位相 *φi* を 一度設定するだけで、AWG カードの ハードウェアで連続正弦波を生成でき ます。実行時には、動的な動作を実現 するために変更のみを送信する必要が あります。

# ■ DDSコアとは?

計算式で表すと、DDSコア出力 uCore,i(t) は、サンプリング周波数 fs でサンプル z ごとに次の計算を実行します:

$$u_{Core,i}(t) = \sin(2\pi \cdot f_i \cdot t + \varphi_i) \cdot A_i$$
  
with  
$$t = \frac{z}{f_s} \text{ and } z = 0, 1, 2, 3 \cdots$$

Example 1をご確認ください。

DDSコアを使用して、振幅90%の 100MHz連続正弦波を出力する例です。 このようにコマンドを送信するだけで DDSコアから任意の正弦波を出力する ことができます。



DDS コアで生成したアナログ信号出力波形

spcm\_dwSetParam\_d64(hCard, SPC\_DDS\_CORE0\_AMP, 0.9); spcm\_dwSetParam\_d64(hCard, SPC\_DDS\_CORE0\_FREQ, 100.0e6); spcm\_dwSetParam\_i32(hCard, SPC\_DDS\_CMD, SPCM\_DDS\_CMD\_EXEC\_AT\_TRG);

**Example 1**: 100MHz で DAC フルスケール範囲の 90% の振幅を持つ連続正弦波を生成する だけの場合は、DDS モードを使用して 3 つの特定のコマンドのみを AWG カードに送信します

# ■ DDSモードの利点

DDSは、サンプルデータの計算タス クをコンピュータではなくAWGカード 上のFPGAで実行します。これは時間 とともに変化する閉じたフィードバッ クループや連続波形データに非常に有 利です。カードに送信する必要がある のは設定値のみなので、転送する必要 があるのは小さなデータのみであり、 バッファ長を小さく保って応答遅延を 減らすことができます。データは FPGA内でオンザフライで生成できる ため、信号の位相を連続的に維持しな がら、外部トリガーイベントに対して 一定の遅延で反応できます。

さらに、さまざまな正弦波信号を生成 するために必要な計算は、多くのユー ザーにとって非常に難しくエラーが発生 する場合があります。DDSは、わかりや すい高レベルのコマンドインターフェイ スを提供することでこの複雑さを軽減 し、プログラミングを容易にします。

### ■ DDSモードの欠点

DDSモードは周期的な正弦波信号を 対象としており、他の信号形式を近似 することもできますが、一般に正弦波 以外の波形が必要な用途ではAWGモー ドの利用が推奨されます。

DDSモードには、非同期トリガー信 号に対して6.6nsのジッターを伴う固 定のタイミング遅延があります。対照 的に、AWGモードには1.25GS/sで 800psなどの単ーサンプルのジッター しかありません。そのため、AWGモー ドと比較すると、DDSモードのトリガー から出力までのジッターは、1.25GS/s フルレートで8倍大きくなります。

# マルチトーン信号生成

DDSモジュールは、1つの基本DDS コアの代わりに、最大N個のDDSコア 1で構成され、その出力はすべて加算さ れて1つ以上のアナログチャネルに出 力されます(Figure1参照)。したがって、 いわゆるマルチトーンまたはマルチ キャリア信号を生成できます。これは、 たとえば量子研究の多くのアプリケー ションに不可欠です。

| <pre>spcm_dwSetParam_d64(hCard,</pre> | <pre>SPC_DDS_CORE0_AMP, 0.05);</pre>               |
|---------------------------------------|----------------------------------------------------|
| <pre>spcm_dwSetParam_d64(hCard,</pre> | <pre>SPC_DDS_CORE0_FREQ, 100.0e6);</pre>           |
| <pre>spcm_dwSetParam_d64(hCard,</pre> | <pre>SPC_DDS_CORE1_AMP, 0.025);</pre>              |
| <pre>spcm_dwSetParam_d64(hCard,</pre> | <pre>SPC_DDS_CORE1_FREQ, 120.0e6);</pre>           |
| <pre>spcm_dwSetParam_d64(hCard,</pre> | <pre>SPC_DDS_CORE2_AMP, 0.05);</pre>               |
| <pre>spcm_dwSetParam_d64(hCard,</pre> | <pre>SPC_DDS_CORE2_FREQ, 140.0e6);</pre>           |
| <pre>spcm_dwSetParam_d64(hCard,</pre> | <pre>SPC_DDS_CORE3_AMP, 0.05);</pre>               |
| <pre>spcm_dwSetParam_d64(hCard,</pre> | <pre>SPC_DDS_CORE3_FREQ, 160.0e6);</pre>           |
| // and so on                          |                                                    |
| <pre>spcm_dwSetParam_i32(hCard,</pre> | <pre>SPC_DDS_CMD, SPCM_DDS_CMD_EXEC_AT_TRG);</pre> |
|                                       |                                                    |

Example 2: 115MHzから90MHzまでの20個の周波数を生成するには、各DDSコアパラメー タを次々にプログラムするだけです。出力範囲の100%を超えないように、コア1を除くす べてのコアで出力振幅を5%に設定します。コア1では、異なる振幅設定の効果を示すために 2.5%を選択しました。そのため、2番目のキャリアの振幅は、信号のスペクトルでわかるよ うに、他のキャリアよりも少し低くなります(Figure1参照)



Figure1:複数の DDS コアを1つのアナログハードウェア チャネルに合計します

簡略化すると、出力 u(t) は次のよう に表すことができます。

> $u_{CH0}(t) = \sum_{i}^{i=N} u_{Core,i}(t)$ With i = DDS core index

すべてのコア振幅値の合計は、最大値 1.0または100%まで加算できます。た とえば、2つのコアを両方とも60%に設 定すると、合計は120%になり、出力で 整数オーバーフロー効果が発生します。

# 疑似コードの利用

Spectrum製カードは C++やPython などのさまざまなプログラミング言語 をサポートしているため、ここでは擬 似コードを使用してコードスニペット の可読性と汎用性を高めます。コード スニペット2は、C++コードスニペッ ト1の結果の擬似コードを示しています。

spcm\_dwSetParam\_d64(hCard, SPC\_DDS\_CORE0\_AMP, 1.0); spcm\_dwSetParam\_d64(hCard, SPC\_DDS\_CORE0\_FREQ, 100.0e6); spcm\_dwSetParam\_i32(hCard, SPC\_DDS\_CMD, SPCM\_DDS\_CMD\_EXEC\_AT\_TRG);

コードスニペット1:C++コード

| CORE0_AMP  | = 1.0         |
|------------|---------------|
| CORE0_FREQ | = 100.0e6     |
| CMD        | = EXEC_AT_TRG |

コードスニペット2:疑似コード

### ■ DDS 設定の変更

周波数、位相、振幅などのすべての設 定は実行時に変更できます。変更は、 EXEC\_AT\_TRIGコマンドを使用して順 番にキューに入れられ、FIFOバッファ リングされ、定義済みのトリガーイベ ントで同時に実行されます。可能なト リガーイベントは次のとおりです。

- カードトリガー:カードで使用可能 なトリガーエンジン全体をサポート します(トリガーエンジンの設定に ついては、ユーザーマニュアルを参 照してください)。
- ・内部タイマー:定義済みの時間間隔
   で次のシーケンスを自動的にトリ
   ガーします。

さらに、EXECUTE\_NOW コマンドを 使用して、キューの最後からDDSモ ジュールに到達するとすぐに変更を実 行できます。

トリガーソースとタイマー間隔は、 他のすべてのパラメーターと同様に変 更できるため、複雑なシーケンスの作 成は簡単です。

DDSモジュールは、すべての操作に 対して固定された時間ベースと固定さ れたタイミング解像度で動作します。

### ■ トリガー分解能とジッターの計算例

M4i.66xxカードのすべてのトリガー ソースのタイミング分解能は *tre* = 6.4ns で、156.25MHzに相当します。

たとえば、内部タイマーの最小値は 83.2nsですが、6.4ns単位で調整できま す。したがって、タイマー値を(10us) に設定すると、正確に10.0032usまた は1563x6.4nsに設定されます。すべて のAWGカードは外部クロックソースに 同期できるため、タイマーの精度はク ロックソースと同等になります。

外部トリガーを使用して次のキュー に入れられたコマンドを実行する場合、 トリガーも 6.4nsのタイミング分解能 で検出されます。トリガーがAWGカー ドに対して非同期の場合、ジッターは +/-3.2ns、つまり合計6.4nsになります。 外部トリガーがAWGカードに同期され、 位相がトリガーエンジンのサンプル& ホールドウィンドウを常に満たすよう に正確に設定されている場合、ジッター を最小限に抑えることができます。

Spectrum製STAR-HUBモジュール を使用することで、複数ボード間のジッ ターを実質的にOnsにすることができ、 複数枚のAWGカードを簡単に同期する ことが可能になります。



# 固有周波数と振幅の傾斜

周波数、振幅、初期位相に加えて、 DDSモジュールは動的パラメータとし て線形周波数と振幅の傾斜もサポート します。

### Example 3:

Figure 2は線形傾斜を使用したシー ケンスプログラミングの例を示してい ます。

シーケンスの順序:

リセット後、すべてのパラメータが0 に設定され、トリガーソースは外部ト リガーに設定されます。

- トリガーイベントで、周波数は20MHz に、振幅は1.0に設定されます。5秒 後に次のシーケンスに切り替えるに は、トリガーソースを内部タイマー に設定します。内部タイマーは5秒 のカウントを開始し、次のシーケン スがトリガーされます。
- コアの周波数は、1秒あたり10MHz ずつ直線的に滑らかに増加します。 したがって、10秒後に最終周波数 120MHzに達します。
- 3. スロープを0に設定して停止し、同時 に振幅を0.6に設定します。
- 最後に、トリガーソースをNONEに 設定して内部タイマーを無効にしま す。

# ■ 周波数と振幅スロープの量子化誤差

スロープは実質的に線形ですが、量 子化されたタイミングと値の解像度を 使用して、カードのロジック内で離散 的なステップで計算されます。

M4i.66xx DDSモジュールの場合、最 小スロープリフレッシュレート  $t_{re}$  は 6.4ns で、この値はほとんどのアプリ ケーションで十分な値です。

これらの量子化された計算により、 スロープの増分とタイミング解像度は 有限であり、目的の設定値と実際の値 の間に一定の量子化誤差が発生する可 能性があります。

通常、これらの影響は最小スロープ ステップに達する秒単位の非常に長い スロープ、またはタイミングの量子化 が関係する短いスロープでのみ目立ち ます。これらの影響を軽減するには、 スロープの最後に最終周波数を手動で 設定する必要があります。

### ■ タイミング量子化誤差

タイミング誤差は、タイマーの浮動 小数点値を入力するときに生成され、 ドライバーによって *tre* ステップで完全 なクロックサイクルに丸められます。 約1ミリ秒の長い傾斜の場合、この量子 化誤差は +/-3.2ns または3.2ppmの範 囲にあり、多くのアプリケーションで は無視できるほど小さいものです。ア プリケーションとプログラミングでこ の量子化を考慮し、*tre* ステップの時間 期間のみを使用することで、この誤差 を軽減できます。

### ■ 動作タイミング誤差

さらに、発生する可能性のある別の タイミング誤差があります。実行イベ ントでスロープコマンドのみを使用す ると、周波数がトリガーイベントと同









時に増加し (Figure3)、予想される終了 周波数になります。

ただし、同じ実行イベントで周波数 とスロープ速度を設定すると、Figure4 に示すように、最初のクロックサイク ルで周波数が設定され、次のクロック サイクルで周波数が増加します。

この動作は技術的には間違いではあ りませんが、スロープは予想されるよ りも1クロックサイクル短くなります。 この動作は、最終周波数を明示的に設 定するか(Figure5)、開始周波数を1増 分だけ調整することで簡単に説明でき ます。

表示目的で 4クロックサイクルという非常に短いスロープ期間が選択されましたが、これは、最小タイマー時間が 100nsの範囲であるため、EXEC\_AT\_ TRIGコマンドではこれまで不可能でした。スロープ期間がミリ秒単位の場合、 この影響は百万分の一単位になります。

### ■ 値量子化誤差

値誤差を減らすために、DDSの周波 数分解能 fstep よりも高い勾配 f'step 分 解能で勾配が内部的に計算され量子化 誤差が減ります。秒単位の長い期間の 場合は、ステップディバイダを設定し て分解能をさらに高めることができま すが、通常ミリ秒単位のタイムスケー ルのアプリケーションでは必要ありま せん。

f'step は、SPC\_DDS\_AVAIL\_FREQ\_SLOPE\_ STEP レジスタを API で読み取ることが でき、fstep は、SPC\_DDS\_AVAIL\_FREQ\_ STEP レジスタで読み取ることができま す。

### Example 4:

M4i.66xx DDS モジュールの周波数分 解能  $f_{step}$  は約0.3Hz です。スロープ速 度を正確に  $f_{step}/t_{re}$  に設定すると、周波 数は6.4ns ごとに正確に0.3Hz 増加しま す。これが最小周波数スロープ分解能  $f'_{step}$  でもある場合、0.3Hz/6.4ns 未満 のスロープ値は不可能になり、スロー プは実行されません。

1秒後、この最小値により周波数は 47MHz変化します。したがって、1秒後 には、0Hz、47MHz、2\*47MHz、3\*47MHz などの量子化された周波数変更のみが 可能になります。

要約すると、最大周波数勾配量子化 誤差を計算するには、勾配分解能と勾 配持続時間を掛けるだけです。中間の 値では、より低い値またはより高い値 に丸めるため、2で割ります。

$$f_{error} = rac{f'_{step} \,\Delta t}{2}$$

実際に実装された周波数勾配分解能  $f'_{step}$ は $f'_{step} = 694$ Hz/sの $f_{step}$ よりも 高くなります。したがって、1MHzから 2MHzへの勾配を1ミリ秒で実現した い場合、最大誤差は

 $\frac{f'_{step} \Delta t}{2} = 0.348 Hz$  になりますが、これはほとんどのアプリケーションでは

| // Set initial V | alues, keep them for one second |
|------------------|---------------------------------|
| TRG_SRC          | = TIMER                         |
| TRG_TIMER        | = 1 s                           |
| COREØ_AMP        | = 1.0                           |
| COREØ_FREQ       | = 100 MHz                       |
| CMD              | = EXEC_AT_TRG                   |
| // Start the Slo | pe                              |
| TRG_TIMER        | = 1 ms                          |
| COREØ_FREQ_SLOPE | = 1 MHz / 1 ms                  |
| CMD              | = EXEC_AT_TRG                   |
| // Stop the Slop | e                               |
| CORE0_FREQ_SLOPE | = Ø                             |
| TRG_SRC          | = NONE                          |
| CMD              | = EXEC_AT_TRG                   |
| コードスニペット 3:10    | 0MHz から 101MHz へのスロープを 1ms で実現  |

無視できる値です。

上記コードスニペット3は、1ミリ秒 で100MHzから101MHzへの勾配を実 現し、101.00000014 MHzで終了します。

# 位相の挙動

Figure2 からわかるように、周波数が 変化しても位相は連続しています。こ れは、位相アキュムレータ  $\theta_i(z)$  を含む DDS コアのより正確な数学的表現に よって説明できます。

 $u_{Core,i}(z) = \sin(\theta_i(z) + \varphi_i) \cdot A_i$ 

 $\theta_i(z) = \theta_i(z - 1) + 2\pi \frac{f_i}{f_s}$ 

リセットまたは位相ジャンプの場合: $heta_i(0) = 0$ 

式からわかるように、周波数  $f_i$  を変 更してもクロックサイクルあたりの位 相増分2 $\pi \frac{f_i}{f_s}$ のみが変わり、位相アキュ ムレータの出力は時間とともに間接的 にしか変化しません。たとえば、周波 数を0に設定すると位相が停止します が、位相コヒーレントDDSでは位相が ジャンプします。

# ■ 位相シフトモード

デフォルトでは、初期位相  $\varphi_i$  を 51° から 52°に変更すると、出力信号の位 相が前の状態に対して 1°変化します。 このモードは、ノブを回して位相を連 続的に調整できる一般的な測定器のよ うに動作します。考えられる用途とし ては、位相シフトキーイング (PSK) な どの変調方式が挙げられます。

### ■ 位相コヒーレント動作/位相ジャンプモード

ー部のアプリケーションでは、周波 数が切り替わるたびに位相がジャンプ する位相コヒーレント周波数スイッチ ングが行われます。この時間多重方式 では、単一のDDSコアを使用して複数 の周波数を同時に出力できます。実際 には、すべての周波数を同時に合計す る場合と比較して、アナログパスから 必要なダイナミックレンジが低くなる という利点があります。

前述のように、位相は通常連続して いますが、DDSモジュールにはコヒー レント動作用の位相ジャンプモードも 備わっており、位相が設定されるたび に位相アキュムレータ  $\theta_i(z) = 0$  がリ セットされます。

### Example 5:

Figure 6は、1つのDDSコアに時分 割多重化された2つの異なる周波数を 示しています。時間平均すると1つの コアのみが使用されていますが、周波 数スペクトルには両方の周波数が表示 されます。 実際のアプリケーションでは、スイッ チングスプリアスの影響を減らすため に、必要な信号周波数よりもはるかに 低いスイッチング周波数を選択するこ とをお勧めします。

この動作を実現するには、スイッチ ングポイントで周波数と位相の両方を 設定する必要があります。スイッチン グポイントで必要な位相を<sup>®</sup>単位で計 算するには、簡単な計算のみです。  $\varphi(t) = f \cdot t \cdot 360^{\circ} mod 360^{\circ}$  $\varphi(1s) = 1.4 MHz \cdot 1 \mu s \cdot 360^{\circ} mod 360^{\circ}$ = 144<sup>°</sup>

 $\varphi(2s) = 3MHz \cdot 2\mu s \cdot 360^{\circ} mod \ 360^{\circ} = 0^{\circ}$ 

 $\varphi(3s) = 1.4MHz \cdot 3\mu s \cdot 360^{\circ} mod \ 360^{\circ} = 72^{\circ}$ 

中間のすべてはハードウェアで計算 されます。したがって、すべてのDDS コアのスイッチング周波数を100kHzの 範囲で簡単に切り替えることができ、 DDSで生成できるトーンの数が実質的 に増加します。

# カスタム周波数スロープ

DDSモジュールは線形勾配のみをサ ポートしていますが、他の勾配タイプ も目的の形状の区分線形補間を形成す る有限数の線形周波数勾配を使用して 簡単に近似できます。たとえば、冷却 原子物理学の世界の多くのアプリケー ションでは、正弦波、いわゆる「S字型」 の周波数勾配が必要です(Figure 7)。 使用用途で必要な滑らかさに応じて、 ユーザーは特定の数のセグメントを選 択できます。表示目的では、Figure 7 に示すように、約7つのセグメントが ターゲットに一致するようです。以下 では、これらの勾配を計算してプログ ラムする方法について説明します。





1. まず、正弦関数を使用して目的のS 字型関数を定義する必要があります。 x=0が傾斜の始まり、x=1が傾斜の終わ りです。





次に、その範囲を必要なステップ数に調整し、完全な整数ステップに量子化します。これは、x = i-nをi:0,1,2,...nに置き換えることで行われます。





3.  $i = 0, 1, 2, \dots$  n-1 の各線形線分の 単位なし勾配 M(i)を計算します。 これらの値は、実行を高速化するため に事前に計算してルックアップテーブ ルに保存できます。 前述のように、位相は通常連続してい ますが、DDS モジュールにはコヒーレ ント動作用の位相ジャンプモードも備 わっており、位相が設定されるたびに 位相アキュムレータ  $\theta i(z) = 0$  がリセッ トされます。

$$M(i) = \frac{\Delta y}{\Delta y} = \frac{yn(i+1) - yn(i)}{1}$$



4. M(i) を使って、 $s(i, \Delta f, \Delta t)$  という 単純な関数を構築できます。この関数 は、M(i) を特定の周波数差  $\Delta f$  と時間 差  $\Delta t$  にスケーリングします。

 $s(i, \Delta f, \Delta t) = M(i) \cdot \frac{\Delta f}{\Delta t}$  $\Delta f = f_{end} - f_{start} = 120 \text{MHz} - 100 \text{MHz}$ = 20 MHz

5. 初期周波数を定義し、開始時に5秒間 保持します。

| CORE0_FREQ | $= f_{start}$ |
|------------|---------------|
| TRG_SRC    | = TIMER       |
| TRG_TIMER  | = 5s          |
| CMD = EXEC | _AT_TRG       |

6. 区分線形 $\Delta i$ シーケンス間の時間 $t_{step}$ を設定します。

TRG\_TIMER =  $t_{step}$ 

7. *i* = 0、1、2、… n-1 の各ステップの 傾きを設定します。

for (i = 0; i < n; i++) { CORE0\_FREQ\_SLOPE =  $f_{start}+s(i\Delta f,\Delta t)$ CMD = EXEC\_AT\_TRG }

8. 最後に最終周波数を設定し、傾きを 停止し内部タイマーを停止します。

```
CORE0_FREQ = f_{end}
CORE0_FREQ_SLOPE = 0
TRG_SRC = NONE
CMD = EXEC_AT_TRG
```

# DDSコマンドを使用したXIO ラインの制御

DDSは3つの異なるXIO出力モード をサポートしています。

### • Manual :

このモードでは、DDSコアの周波数 と同様に、出力状態(highまたはlow) を制御できます。

### • Wait for trigger :

XIO ラインは、DDS モジュールがト リガーを待機しているかどうかを示す ステータス信号として機能します。 EXECUTE\_AT\_TRIGを受信した後、DDS モジュールがトリガー待ちを開始する と、XIO ラインは high になります。プ ログラムされたトリガー信号 (タイマー またはカードトリガー)を受信すると、 XIO ラインは low になります。

### • Execute :

XIO ラインはステータス信号として 機能し、トリガーまたは今すぐ実行コ マンドが受信され、新しいパラメータ が出力にロードされるたびに high にな ります。

すべての信号は出力に合わせて調整 されます。例については、Figure 15 を 参照してください。

したがって、「Manual」モードに設定 されたXIOラインをlowからhighに変 更し、同じトリガーイベントで出力振 幅を0から100%に変更する場合、両方 の変更をほぼ同時に測定できます。振 幅と手動XIOラインの変更と同時に、 「Execute」モードに設定されたXIOラ インが6.6ns の間highになり、その後 lowになります。「Wait for trigger」ライ ンは、トリガーが到着すると同時にlow になり、次の「EXECUTE\_AT\_TRIG」コ マンドがカードに送信されるとすぐに highになります。

ソフトウェア駆動のフィード バックループ / 意思決定

AWGカード、ブラックボックスシス テム、デジタイザーで構成される閉じ たフィードバックループを想像してく ださい。このループ内でAWGは周波数 fを使用してシステムを刺激し、システ ムは周波数を急速に上げるか、周波数 を下げるようにシステムに信号を送る ことで応答します。

この例では、新しい周波数値は一定 の応答時間 *tresponse* 内にシステムに到達 する必要があります。この応答時間は Figure 8に示されており、3つの異なる 主要コンポーネントで構成されていま す。

 $t_{response} = t_{measure} + t_{processing} + t_{latency}$ 

- *t<sub>measure</sub>*は、変化した入力信号を測定 するのにかかる時間です。
- *t*<sub>processing</sub>は、必要な新しい出力パラ メータ/データを計算する時間です。
- t<sub>latency</sub>は、ソフトウェアが新しいパラ メータを設定してからカード出力に 至るまでの遅延です。

トリガーイベントに必要な周波数が 事前にわかっていれば、次のトリガー



イベントの周波数値をプリロードして、 1マイクロ秒以内に簡単に反応できま す。これが「Trigger-to-Output」の時間 です。ただし、このリアルタイムフィー ドバックアプリケーションでは、次に どの出力周波数が必要になるかは事前 にわかりません。

つまり、新しい入力パラメータを受け取った後にどのように反応するかを 決定し、時間内に反応を実行する必要 があります。

以前のAWG FIFOモードでは、新し いデータを最初に計算してからAWGメ モリに送信する必要がありました。こ のバッファリングのため、システムで 大きな遅延が発生します(通常は数ミ リ秒程度)。AWGシーケンスモードでは、 事前に保存されたシーケンスを切り替 えることでこの時間を短縮できます。 ただし、切り替えプロセスによって時 間の不確実性(数百ナノ秒程度)が生じ る可能性があります。

DDSモードでは、必要な出力周波数 のみを計算し個々のサンプルの長い シーケンスを計算する必要がないため、 処理時間を短縮できます。さらに、転 送するデータは最小限であるため、バッ ファリングが最小限で済み遅延時間も 大幅に短縮できます。

要約すると、新しいDDSモードは2 つの異なる実行コマンドをサポートし ています。EXEC\_NOWでは、新しい周 波数値を可能な限り高速に出力にロー ドできます。

EXEC\_AT\_TRIGでは、新しい値が明 確に定義されたタイミングで選択され たトリガー ソースに正確にロードされ ます。したがって、最速の応答時間を 実現するには EXEC\_NOW を使用でき ますが、確定的なタイミングと特定の レイテンシを実現するには、EXEC\_AT\_ TRIGを使用する必要があります。これ については、次のセクションでさらに 詳しく説明します。

# ■ EXEC\_NOW で応答時間を測定する

ソフトウェアから物理的な出力まで の遅延時間 *tlatency* を測定するのは非常 に困難です。キーを押してから文字が 表示されるまでの時間を測定すること を想像してください。指の押下によっ て定義される開始時間は、ミリ秒のオー ダーで測定する場合、非常に不正確です。

ただし、完全な応答時間 tresponse は簡 単に測定できます。つまり、処理シス テムがソフトウェアでポーリングして 入力の変更を検出し、新しい周波数値 を送信して別の信号を出力するのにか かる時間です。ここで、ADCの代わり にM4iカードにすでに搭載されている2 つの補助デジタルIOラインを使用しま す。IOラインXIO-0がHighになると、 周波数を可能な限り速く上げ、XIO-1が Highになると周波数を下げます。XIO ラインはトリガー入力としては使用さ れず、ソフトウェアによってポーリン グされるだけであることに注意してく ださい。

このパラメータは、さまざまなシス テムとプログラミング言語でテストさ れています。いくつかのコマンドの結 果を、Table 1: レイテンシ測定結果に示 します。ただし、すべての非リアルタ イムオペレーティングシステムと同様 に、これらのレイテンシ値は保証され ていません。たとえば、ウイルススキャ ンによってシステムが停止しレイテン シが大幅に増加する可能性は常にあり ます。そのため、次のセクションで説 明する「詳細なテスト設定」を使用して、 独自のシステムでこの値をテストする ことをお勧めします。

### ■ 詳細なテスト設定

IO ラインXIO-0およびXIO-1の信号 ソースとして、2つのプッシュボタンを 使用します。反応するソフトウェアに よって導入された変更の結果を明確に 確認するために、別のIOライン XIO-2 を出力として使用し、これをlow(0)か ら high(1)に切り替えます。また、信号 周波数を変更するアナログ出力を使用 します。

| Condition                             | Typical achievable Roundtrip Times |
|---------------------------------------|------------------------------------|
| C++ on Windows 10, Intel i7 13700k    | 20 µs                              |
| Python on Windows 10, Intel i7 13700k | 70 µs                              |
|                                       |                                    |



// Send initial Values X0 MODE = ASYNC IN X1 MODE = ASYNC IN X2\_MODE = DDS\_MANUAL COREØ AMP = 1.0 COREØ\_FREQ = 0.5 MHz MANUAL\_OUTPUT = X2 -> 0 CMD = EXEC\_AT\_TRG CMD = WRITE TO CARD M2CMD\_CARD = FORCETRIGGER // Poll XIO Lines until either one is High while (1) if (get\_param(XIO0) == 1) COREØ FREO = 0.1 MHzCOREØ AMP = 1.0 MANUAL\_OUTPUT = X2 -> 1 CMD = EXEC NOW CMD = WRITE\_TO\_CARD break; else if (get\_param(XI01) == 1) CORE0\_FREQ = 1 MHz COREØ AMP = 1.0 MANUAL\_OUTPUT = X2 -> 1 = EXEC NOW CMD CMD = WRITE TO CARD break; } } レイテンシテストを出力するソフトウェアの擬似コード





最後に、IOラインXIO-0またはXIO-1 がhighになってから出力信号が変更さ れるまでの時間遅延が、私たちが関心 のあるものです。この時間は、オシロ スコープを使用して表示および計算で きます。

# ■ EXEC\_AT\_TRIG による確定的 レイテンシの実現

外部トリガーから出力周波数の動的

変更までのレイテンシは、固定遅延を 持つ2つのトリガーイベントを使用す ることで固定できます。最初のトリガー イベントは新しい入力パラメータの読 み出しをトリガーするために使用され、 2番目のトリガーは新しい周波数値を実 行するために使用されます。

たとえば、外部トリガーイベントに 対するソフトウェアの応答時間が最大 20µsから80µsの間で変動することが わかっている場合は、2番目のトリガー イベントを最初のトリガーイベントの 100µs後に設定します。

これで、新しい周波数値は常に最初 のトリガーイベントの 100µs後に出力 されます。2番目のトリガーイベントで は、再び外部トリガーまたは組み込み タイマーを使用できます。

# ■ テストセットアップ

M4i.66xxシリーズのカードはトリ ガー入力としてXIOラインをサポート していないため、次の周波数を選択す るには別の方法を使用する必要があり ます。そのため、AWGカードのトリガー 入力TRGOに接続された1つのプッシュ ボタンを使用し、IO ラインXIOO にス イッチを接続します。プッシュボタン によって生成されたトリガーイベント でスイッチがhighの位置にある場合は、 周波数A出力が必要になり、スイッチが low の位置にある場合は周波数 B 出力が 必要になります。そのため、最初にス イッチを目的のXIO-0レベルに設定し てから、ボタンを押す必要があります。 これらの信号をデジタルで制御する場 合は、もちろん、トリガーと同時に XIO-0ラインを切り替えることができ ます。

プログラミングに関しては、XIO ライ ンが変更されたかどうかをポーリング する代わりに、カードのトリガーエン ジンを使用します。ここでは、TRGOが ハイになるとトリガーするように設定 します。DDSには、トリガーが受信さ れるとlowになるステータス信号 「WAITING\_FOR\_TRIG」があります。こ の信号がlowになるまでポーリングし、 XIO-0が0または1のどちらをリード バックするかを確認します。これに応 じて、次のトリガーイベントの値を設 定します。

2番目のトリガーイベントで確定的な レイテンシを実現するには、最初のト リガーイベントで組み込みのタイマー トリガーを選択して100µsに設定しま す。

IOラインの値は、トリガーが押され た時点とタイマートリガーが次のシー ケンスを実行する時点の間のどこかで 1回だけ評価されます。したがって、 Figure 13とFigure 14のXマーカーは、 「Don't Care」の信号領域を示します。



```
frequency_initial
                         = 100 \text{ kHz}
frequency_a
                         = 20 \text{ kHz}
frequency_b
                         = 300 \text{ kHz}
XØ MODE
              = ASYNC IN
X2 MODE
              = DDS MANUAL
// Setup the card trigger engine to trigger on EXT0
TRIG_ORMASK
              = SPC_TMASK_EXT0
// Send initial Values
COREØ_AMP
              = 1.0
COREØ_FREQ
              = frequency_initial
MANUAL OUTPUT = X2 \rightarrow 0
CMD
              = EXEC_AT_TRG
              = WRITE_TO_CARD
CMD
// Force Trigger initial settings
M2CMD_CARD
              = FORCETRIGGER
/* This yellow marked EXEC_AT_TRG is triggered by the external
Trigger and starts the timer for the NEXT Blue EXEC AT TRG */
DDS_TRIG_SRC = TIMER
TIMER
               = 100µs
CMD
              = EXEC_AT_TRG
              = WRITE_TO_CARD
CMD
// Wait until we received the trigger
while (get_param(WAITING_FOR_TRIG) == 1)
   {
   // Wait
   }
/* Send new Data based on IO Line state.
The Data needs to be send before the timer runs out */
if (get_param(XIO0) == 0)
   COREØ_FREQ
                   = frequency_a
   MANUAL_OUTPUT
                   = X2 - > 1
   CMD
                   = EXEC_AT_TRG
   CMD
                    = WRITE_TO_CARD
  }
else
   COREØ FREQ
                    = frequency_b
   MANUAL OUTPUT
                   = X2 -> 1
                   = EXEC AT_TRG
   CMD
   CMD
                    = WRITE_TO_CARD
   }
          決定論的な遅延を伴う意思決定のための疑似コード
```



Figure 13: 意思決定テストによる確定的レイテンシの出力波形画像。決定 A、XIO-0 は外部トリガーイベントで low になります。 $t_{response} = 100 \mu s$ 



Figure 14:意思決定テストによる確定的レイテンシの出力波形画像。決定 B、XIO-0 は外部トリガー イベントで high になります。 $t_{response} = 100 \mu s$ 

# 継続的なストリーミング

101.3 MHzで独自のFM ラジオ局を 作成し、AWG カードをソフトウェア定 義ラジオ (SDR) として使用するとしま す。前述のように、以前はサンプルご とにデータをストリーミングする必要 があり、1.25GHzのサンプルレートで 2GB/sを超えるデータストリームが発 生しました。これには通常、専用の CUDA GPUアクセラレータカードが必 要でした。

現在、DDSモードでは、新しい周波

数値で構成される周波数変調信号のみ を送信する必要があります。20kHz帯 域幅のオーディオ信号の場合、44.1kHz のサンプリングレートが一般的です。 この信号は、最小限の計算能力でDDS に継続的にストリーミングできます。

ストリームの信頼性を高めるために、 大きなFIFOバッファを使用できます。 Spectrum APIは、各コマンドを64ビッ ト、つまり8バイトに収めます。これに より、カードの4GBオンボードメモリ に最大5億のコマンドを保存できます。 ただし、これによりストリームのレイ テンシも増加します。44.1kHzのコマ ンドレートでバッファがいっぱいにな ると、遅延は3時間強になります。た だし、バッファリングするコマンドの 最大数はいつでも選択できます。

### ■ 最大ストリーミング速度

ストリーミング速度は、ユーザーア プリケーションとシステムに大きく依 存します。M4i.66xxでのPython実装 によるテストでは、約300kHzの信頼性 の高い速度に達し、C++では10MHzを 超える連続ストリーミングコマンド レートが正常にテストされました。

# Execute-Nowを使用した シングルステッププログラミング

20秒間という長い期間にわたって 100MHzの連続信号を生成し、その間に 数ナノ秒ごとに変化する短い任意の信 号を追加したいとします。残念ながら、 タイマーの再アーム時間は 100ns程度 と最小限です。ただし、より複雑な「1 つの命令」/クロックサイクルアプロー チを使用すれば、出力信号を6.4nsごと に変更できます。

これは、Execute-At-Trigコマンドの 代わりに単一のExecute-Nowコマンド を使用することで可能になります。こ れらのコマンドは、コマンドキューの 最後に到着するとすぐに実行されます。 したがって、キューの状態に応じてタ イミング動作が異なります。

- ・キューが空でカードがトリガーを待 機していない状態でカードに送信さ れた場合、それらは「ソフトウェアか ら出力までの遅延」で定義された可能 な限り高速に実行されます。
- 2つの Execute-Now コマンドが キューに続けて入れられた場合、そ れらは6.4ns間隔で実行されます。
- Execute-Now コマンドがExecute-At-Trigコマンドの後にキューに入れ られた場合、それらはトリガー後の 固定遅延時間 t1 で実行されます。

# Example 6:

トリガー信号の後に正弦波を出力し、 XIO 出力2 を使用してデジタルデバイ スを制御するとします。デバイスは、 Figure 15に示すように、0'と1'の特 定のシーケンスを期待します。右のリ ストは対応するコマンドリストです。

# ■ M4i.66xxカードのDDSモード とAWGモードの比較

AWGモードは、出力信号を事前に計 算してメモリに保存できる場合に最適 です。そうでない場合は、ループ、スト リーミング、またはシーケンスモード を使用する必要があり、セットアップ が少し複雑になります。

閉ループフィードバックシステムが ある場合は、高レイテンシでデータを ストリーミングするか、シーケンスモー



Figure 15:さまざまな XIO 出力モードと単一の「Execute-Now」コマンドを使用した波形画像

| COREØ_AMP<br>COREØ_FREQ<br>MANUAL_OUTPUT<br>CMD                                                                                                                                       | = 0.7<br>= 30 MHz<br>= X2 -> 1<br>= EXEC_AT_TRG                                                                                                                                                                                                                                                                                                                                                            |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MANUAL_OUTPUT<br>CMD<br>MANUAL_OUTPUT<br>CMD<br>MANUAL_OUTPUT<br>CMD<br>MANUAL_OUTPUT<br>CMD<br>MANUAL_OUTPUT<br>CMD<br>MANUAL_OUTPUT<br>CMD<br>MANUAL_OUTPUT<br>CMD<br>MANUAL_OUTPUT | = $X2 \rightarrow 0$<br>= $EXEC_NOW$<br>= $X2 \rightarrow 1$<br>= $EXEC_NOW$<br>= $X2 \rightarrow 0$<br>= $EXEC_NOW$<br>= $X2 \rightarrow 0$<br>= $EXEC_NOW$<br>= $X2 \rightarrow 1$<br>= $EXEC_NOW$<br>= $X2 \rightarrow 2 \rightarrow 0$ |
| コマント                                                                                                                                                                                  | ドリスト                                                                                                                                                                                                                                                                                                                                                                                                       |

# まとめ

DDSファームウェアオプションは、 その高い柔軟性により幅広いアプリ ケーションをサポートします。レイテ ンシを削減できるため、従来のAWG モードよりも多くの使用用途が可能に なります。さらに、プログラミングが 容易になり、これまでAWGモードが使 用されていた既存のアプリケーション が簡素化されます。

つまり、M4i.66xxシリーズ Spectrum 製カードは、信号生成カードの無数の アプリケーションをサポートします。

ドを使用する必要があります。

信号が正弦波で構成されている場合 は、DDSコマンドを使用して記述する だけです。内部カードバッファに制限 されず、バッファサイズを計算する必 要もありません。バッファリングする 必要があるデータの量は非常に少ない ため、コマンドFIFOのレイテンシを非 常に短く抑えることができます。実行 時(シーケンス)にDDS設定を切り替 えると、外部トリガーから出力までの レイテンシ時間が固定されます。変更 を送信するだけでよいため、連続デー タ生成には多くの計算能力は必要あり ません。 リファレンスドキュメント: Spectrum Instruments社 Product Note:Using the DDS Mode



# TECHNOLOGY

# AWGでダイレクトデジタル合成 (DDS)を 使用する利点

# はじめに

任意波形発生器 (AWG) は、電子テス トに使用できる最も強力で柔軟性の高 い信号源の1つです。AWGは、帯域幅 と波形メモリの長さの範囲内で、ほぼ 無限の数の波形を生成できます。AWG から信号を出力するためには、有用な 波形を作成する必要があります。AWG 用のアプリケーションソフトウェアを 使用すると、方程式を使用して非常に 正確な波形を作成したり、デジタイザ またはデジタルオシロスコープを使用 してキャプチャした波形データを再生 したりできます。テスト波形の作成、 キャプチャ、変更、転送にかかるコスト は非常に高額になる可能性があるため このプロセスを簡素化するツールは非 常に貴重です。

# DDSオプション

Spectrum 社は、16ビットの任意波形 発生器 (AWG) シリーズ向けに、ダイレ クトデジタル合成 (DDS) ファームウェ アオプションをリリースしました。 DDSは、単一の固定周波数リファレン スクロックから周期的な波形を生成す る方法です。このDDSオプションは、 複数の「DDSコア」を使用して各キャリ アの周波数、振幅、位相が明確に定義さ れたマルチキャリア (マルチトーン)信 号を生成します。Figure 16 は、最大 1.25GS/sおよび400MHzの信号帯域幅 を備えたM4i.66xxシリーズ AWGでの DDS信号生成のアーキテクチャを示し ています。DDSオプションの信号ルー ティングにより、使用可能なDDSコア と出力チャネル間のさまざまな接続が 可能になり、最大限の柔軟性が得られ ます。M4i.66xxシリーズ向けに最初に



リリースされたDDSオプションでは、 合計23個のDDSコアが使用され、最大 20個のDDSコアが1つのチャネルに ルーティング可能になります。

正弦波出力のプログラミング

DDSオプションは、波形作成におい て大きな利点があります。AWG波形は、 ポイントごとに記述する必要がありま す。1メガサンプルの波形がある場合、 その波形のすべての電圧値を計算して 波形メモリに保存する必要があります。 これに対し、DDSオプションは簡単な コマンドで記述されます。Figure 17は、 100MHz正弦波を生成する方法の例を 示しています。これらのシンプルなテ キストベースのソースコマンドは、コ ンパイルされた後さらに簡潔な形式で DDSファームウェアに送信され、同等 のAWG波形よりもはるかに少ないメモ

リで実行します。この例では、周波数 と振幅が指定されています。コマンド は、Python、C/C++、MATLAB、 LabVIEW、およびその他の多くのプロ グラミング環境で記述できます。

各キャリアの振幅、周波数、位相を設 定でき、さらに周波数または振幅の線 形変化を指定できます。たとえば、 250MHzキャリアに対して5MHzのレー ダーチャープを生成する場合のDDSコ アコマンドは右のとおりです。(Code1 参照)

周 波 数 は 247.5MHz から 始まり、 10μs かけて 252.5MHz まで直線的に増 加します。信号のFFT スペクトルを Figure 18に示します。

方程式を使用してAWGで同じ波形を 計算するには、1.25GHzのサンプリン グレートで12500サンプルの電圧値を 計算する必要があります。

対照的に、DDSコアはわずか6つの コマンドを使用して同じ信号を生成し ます。さらに、これらのコマンドは、そ れぞれが 64ビットつまり8バイトに収 まる最適化されたドライバーを介して AWGに送信されます。これにより、 AWGの4GBオンボードメモリに最大5 億のコマンドを保存できます。

DDSコマンドは、ユーザーが指定し たトリガーイベントと同期して実行さ れます。トリガーイベントには、AWG カードの内部トリガーロジックで生成 されたものや、この場合のように内部 タイマーを使用して生成されたものが 含まれます。慎重に設計することで、 DDS出力は、わずか6.4nsの分解能で 任意の外部トリガーイベントまたはプ ログラム可能なタイマーと同期できま す。

各コアは、独自の変調正弦波を生成 できます。別のレーダーの例として、 250MHzのキャリア、10kHzのパルス繰 り返し周波数 (PRF)、10μsのパルス幅 を持つレーダーパルス列を生成するこ とが挙げられます。DDSコマンド例は 右のとおりです。(Code2参照)



// Chirp, 10µs duration, linear frequency sweep starting at 247.5 MHz to 252.5 MHz CORE0\_FREQ = 247.5 MHz CORE0\_FREQ\_SLOPE = 5/10 MHz/µs CORE0\_AMP = 1.0 // 100% Amplitude TRG\_SRC = TIMER TRG\_TIMER = 10µs CMD = EXEC\_AT\_TRG

Code1: 250MHz キャリアに対して 5MHz のレーダーチャープを生成する場合のコマンド例



Figure 18 : レーダーチャープの FFT スペクトルは、247.5MHz から 252.5MHz までの周波数の線形変化を示します

```
/ Initial Settings
PHASE_BEHAVIOR = JUMP
COREO_FREQ = 250 MHz
TRG SRC = TIMER
for(i = 0; i < pulse_count; i++){</pre>
       // Switching on for 10 µs
       COREØ PHASE = 0 // Start at Phase 0 each Cycle
       COREO AMP = 1.0 // 100% Amplitude
       TRG_TIMER = 10\mu s
       CMD = EXEC AT TRG
       // Switching of for 90µs to get 10kHz repetition Rate
       CORE0 AMP = 0
       TRG_TIMER = 90\mu s
}
Code2: 250MHz のキャリア、10kHz のパルス繰り返し周波数 (PRF)、10µs のパル
        ス幅を持つレーダーパルス列を生成するのコマンド例
```



Figure 19 : DDS オプションを使用して作成された、250MHz キャリア、10kHz PRF、および 10μs パルス幅のレーダーパルス。1 目 盛りあたり 100μs (上) および 2μs (下)の水平スケールで表示されます

結果として得られるパルスストリー ムをFigure 19に示します。

これは、正弦波キャリアをゲートす る機能を示しています。キャリア振幅 をゼロに設定するとオフになります。 振幅を設定する同じ手法を使用して、 キャリアを振幅変調することができま す。

# デュアルトーン波形

DDSオプションでは、複数の加算キャ リアを作成できます。マルチキャリア 波形の最も一般的な使用法は、相互変 調歪み(IMD)テストです。デュアル トーン波形(異なるキャリア周波数の 正弦波)を加算してデバイスに適用し ます。デバイスの非線形性により、特 定の周波数で混合信号が発生します。 デバイスの出力スペクトルには、元の 信号周波数、和周波数と差周波数、およ び和周波数と差周波数の倍数である相 互変調生成が含まれます。IMDレベル は、相互変調生成の電力と目的の出力



信号の変調生成が含まれます。IMDレ ベルは、相互変調生成の電力と目的の 出力信号の電力の比で、デシベル (dB) で表されます。IMDレベルが低いほど、 デバイスのパフォーマンスは向上しま す。Figure 20 は、ツートーンテストの 例を示しています。

使用される2つのトーンは32MHzと 34MHzです。左側に示されている合計 信号は、周期的に干渉し合い、互いに強 め合い、結果としてビート音になりま す。スペクトルには、2つの元の周波数 と、すべての混合および相互変調信号 が表示されます。これらは2MHzの差 周波数で間隔が空いています。

# マルチトーン波形

マルチトーン正弦波は、アナログ-デ ジタルコンバータ (ADC) のパフォーマ ンスを迅速に評価するために使用でき ます。下の表は、15個の正弦波を加算 したテスト波形の成分の周波数と振幅 を示しています。スペクトラムアナラ イザで表示される結果の波形をFigure 21に示します。

| Frequency<br>(MHz) | Amplitude<br>(%) | Relative<br>Amplitude (dB) |
|--------------------|------------------|----------------------------|
| 34.0               | 50               | 0                          |
| 33.5               | 25               | -6                         |
| 33.0               | 12.5             | -12                        |
| 32.5               | 6.25             | -18                        |
| 32.0               | 3.125            | -24                        |
| 31.5               | 1.562548         | -30                        |
| 31.0               | 0.781274         | -36                        |
| 30.5               | 0.390637         | -42                        |
| 30.0               | 0.195318         | -48                        |
| 29.5               | 0.097659         | -54                        |
| 29.0               | 0.04830          | -60                        |
| 28.5               | 0.024415         | -66                        |
| 28.0               | 0.012207         | -72                        |
| 27.5               | 0.006104         | -78                        |
| 27.0               | 0.003052         | -84                        |





スペクトラムアナライザはトーン振 幅の直線性を示します。

デジタイザに適用すると、Figure 22 の結果の表示はデジタイザのダイナ ミックレンジと直線性を示します。

デジタイザの応答は、トーン振幅の 読み取りに優れています。一部の相互 変調成分は、-90dBを大きく下回る振幅 で現れます。このシンプルな波形から、 デジタイザの応答の品質の高さを把握 できます。 マルチトーンマルチ出力アプリケーション

これまで説明したマルチトーン信号 は合計され、1つのチャネルから出力さ れます。

また、複数のチャネルから単一の正 弦波を出力することもできます。フェー ズドアレイシステムの駆動などのアプ リケーションでは、個々の正弦波の振 幅と位相の制御を使用して、アンテナ またはトランスデューサーのアレイの 波面を操作またはフォーカスします。



Figure 23は、この機能を簡略化した 図を示しています。

波形が同じ位相でエミッターに到達 した場合、波面はフラットまたはブロー ドサイド形状になります。波形をエミッ ター全体で直線的に位相遅延させるこ とにより、波面を操縦できます。最後に、 波形の位相を調整して中心近くのエ ミッターが最初に到着し、外側のエミッ ターが後で駆動されるようにすること でアレイをフォーカスできます。

Figure 24は、ブロードサイドまたは 無指向性アライメントの場合と、45度 下方向に操縦された指向性波面の場合 の8素子フェーズドアレイを駆動する ための波形を示しています。

赤いカーソルは、両方のインスタン スの素子0波形の3番目のサイクルの ピークを示します。無指向インスタン スのすべての波形は同じ位相を持ち、 カーソルはすべての素子波形の3番目 のサイクルのピークに配置されます。 指向波形素子では、連続する各素子の 素子位相が徐々に遅れていることがわ かります。

この例では8チャネルを使用します が、これはSTAR-HUBオプションと同 期された2つの4チャネルM4i.6622-x8 AWGを使用して実現できます。最大8 枚のPCleカードを使用するシステム、 合計32チャネルのシステムも同じ方法 で構築できます。LXI/Ethernetベース の機器が望ましい場合は、最大24チャ ネルのDNシリーズジェネレータ NETBOXユニットも利用できます。

### 直交変調

DDSオプションでは、位相変調信号 の生成も可能です。直交変調は位相変 調に基づいており、データ通信システ ムで使用されます。直交位相シフトキー イング (QPSK) は、送信シンボルごと に2ビットをエンコードする変調方式 です。これは、同相 (I) データストリー ムと直交 (Q) データストリームと呼ば れる 2つのバイナリ位相シフトキーイ ング (BPSK) データストリームを作成 することによって生成されます。|信号 とQ信号は直交して合計され、QPSK信 号が生成されます。これらの信号は、 180度の差がある2つのバイナリ状態を エンコードします。DDSオプションで は、Figure 25 に示すようにこれらの波





形を簡単に生成できます。

2つのBPSK信号はそれぞれ2つのバ イナリ状態のみを持ち、変調器で結合 されて4状態のQPSK信号を形成しま す。この例では、バイナリデータの送 信された1および0状態に対応するプラ スおよびマイナス180度の位相シフト を使用して、100MHzのキャリアを 5MHzのシンボルレートで位相変調し ます。

まとめ

AWG用のSpectrum製 DDSオプショ ンは、AWG機能に、生成と制御が簡単 な複数の正弦波出力を追加することで、 AWG製品の汎用性を高めます。DDSオ プションのシンプルなテキストベース のコマンドは、正弦波の振幅、周波数、 位相を制御し、より応答性の高い制御 のために、より大規模なサンプル値ベー スのAWG波形を正弦波に置き換えます。 DDSオプションは、通信、医療、画像処 理、産業システムなど、高速周波数切り 替え、細かい周波数、位相、振幅制御を 使用するアプリケーションに適用でき ます。

```
// I Signal on Channel 0, CORE 0
// Q Signal on Channel 1, CORE 20
PHASE BEHAVIOR = SHIFT
COREØ_FREQ
               = 100 MHz
CORE0_AMP
               = 1.0
CORE20_FREQ
               = 100 MHz
CORE20_AMP
               = 1.0
// 10 MHz Sampling Rate by using the Timer
TRG SRC
               = TIMER
TRG_TIMER
               = 0.2µs
bool iq_data[64][2];
                        // 64 QSPK Symbols with 1 I and 1 Q Bit
                        // n'th I-Bit at Index [n][0], Q-Bit at Index [n][1]
// Fill IQ Data with 128 Bit of a Pseudorandom Binary Sequence
iq_data = generate_PRBS_data(128)
for (i = 0; i < 64; i++)</pre>
{
    COREØ PHASE
                  = 0° + iq_data[i][0] * 180°
                  = 90° + iq_data[i][1] * 180°
    CORE20_PHASE
    CMD
                   = EXECUTE_AT_TRIG
}
           Code3: 直交変調により I/Q 信号を生成する場合のコマンド例
```



リファレンスドキュメント: Spectrum Instruments社 Application Note:Using DDS Mode in different Applications



# ADVANCED

# 2枚のデジタイザを使用して20GSPSを 実現する方法

# はじめに

この記事で実現する内容は以下のと おりです。

- 2枚の10GSPS 12bit デジタイザ (ADQ35)を時間インターリーブして 20GSPSを実現
- DC ~ 2.5GHzの入力周波数範囲で
   4ps未満のタイミング誤差を実現
- ・各デジタイザは PCle 経由で12.8GB/
   sでデータを GPU にストリーミング する

デモセットアップのブロック図を Figure 26、ADQ35を2枚実装したテス トシステムの写真をFigure 27に示します。

# アプリケーション

2枚のデジタイザで、分割されたアナ ログ入力信号を時間インターリーブ方 式でサンプリングします。これは、一 方のデジタイザで、入力リファレンス クロックを遅延/スキューするオンボー ド機能を使用することで実現されます。

取得したデータの後処理はGPUで実 行されます。信号処理のベクトル最適 化されたCPU処理の実装は計算上十分 かもしれませんが、比較的高い帯域幅 を処理するため処理タスクにはGPUを 選択します。



システムを選択する際に考慮すべき 主な点は、PCIeとGPUメモリ帯域幅で す。PCIe帯域幅は、CPUのPCIeレー ンの数とマザーボード上のレーンの ルーティング方法に分けられます。 ADQ35は、x16レーンのGen3 PCIe





Figure 27:2枚の ADQ35 をインストールしたテスト PC

インターフェイスを介して最大14GB/s でデータをストリーミングできます。

より新しいGPUには、x16レーンの Gen4 PCleインターフェイスが搭載さ れています。Gen4へのアップグレード により帯域幅が2倍に増加します。

これを考慮すると、システムにはx16 レーンのGen4 PCleポートが1つとx16 レーンのGen3 PCleポートが2つ必要 です。

# ハードウェアの詳細

使用されるシステムには以下のハー ドウェアが含まれます:

- ・AMD EPYC 7282 CPU、128 個 の Gen4 PCIe レーンを提供
- ・SUPERMICRO H12SSL-Iマザーボー ド、5つのx16レーン Gen4 PCleポー トを提供
- ・NVIDIA A2000 GPU、288GB/s VRAM 帯域幅とGen4 x16 PCIeインターフェ イスを提供

# 2枚のADQ35デジタイザへの信号入力

デジタイザ間のサンプリングクロッ クの位相差を制御できるように、分割 された10MHzクロックリファレンスが 各デジタイザのclkコネクタに接続され ます。クロックの位相は各 ADQ35に組 み込まれた微調整遅延ラインによって 調整されます。

単一トリガーコマンドを両方のボー ドに配布できるように、ソフトウェア コマンド SWTrig()で同期コネクタにパ ルス出力を生成します。一方のデジタ イザの同期コネクタからの出力は分割 され各デジタイザのトリガーコネクタ に接続されます。次に、各デジタイザ のトリガーポートは、トリガーイベン トを10MHzクロックリファレンスに同 期するように構成されます。これによ り、両方のカードで同時にデータの取 得を開始できます。

ケーブル接続をFigure 28に示します。 コネクタとその設定方法については、 『ADQ3シリーズデジタイザ - ユーザー ガイド』で説明されています。



Figure 28: デジタイザへのケーブル接続

ソフトウェアの詳細

- ・オペレーティングシステムは Ubuntu 20.04.6 LTS
- ・デジタイザーファームウェアと ADQAPI のリリースパッケージ 2024.1
- ・NVIDIAドライバー 550.54.14、CUDA 12.4

# サンプルコード

サンプルソフトウェアである calibrate. py と interleave.py は、Teledyne SP Devices 社リリースパッケージで提供 される2つの Python サンプルスクリプ トに基づいています。これらは、examples/ python/data\_transfer\_gpu\_nvidia フォ ルダーにあります。

data\_readout スクリプトは最も基本 的な例です。APIの簡略化された data\_ readout機能を使用してデジタイザから データを取得します。詳細については、 ExampleのREADMEファイルを参照し てください。

スクリプトdata\_transfer\_gpu\_nvidia は、低レベルのAPI機能を使用してデジ タイザから NVIDIA GPUにデータを移 動します。詳細が記載された独自の READMEもあります。

両方のスクリプトで必要な主な変更 は次のとおりです。

- ・2つのデジタイザをサポートするよう に拡張します。
- ・デジタイザを構成して10MHzリファ レンスクロックを使用します。
- Clock\_system.delay\_adjustment\_ enableを設定します。
- トリガーポートを使用してイベント を作成しレコードの取得を開始しま す。これらのイベントを10MHzリ ファレンスクロックに同期します。

- ・(1枚のカードの場合) パルスジェネレーターを構成して、ソフトウェアトリガーで開始し同期コネクタでパルスを出力します。
- (1枚のカードの場合) clock\_system.
   delay\_adjustmentを構成します。

# calibrate.py

2枚のカードが互いに180度位相がず れた信号をサンプリングする clock\_ system.delay\_adjustment の値を見つ けるための1つの方法は、既知の正弦信 号を提供することです。両方のデジタ イザからサンプリングされたデータに 正弦関数を当てはめます。これらの関 数から必要な遅延を計算します。これ は、標準サンプル data\_readout.pyに基 づく calibrate.py で実装されています。 操作のフローチャートを Figure 29 に 示します。

### ■ interleave.py

このスクリプトはデータ転送を使用 して、2つのデジタイザからGPUのメ モリに直接データを移動します。 calibrate.pyと異なるのは、SWTrig()呼 び出しがパルスジェネレータをすぐに 起動しないことです。代わりに、同期 コネクタに出力を作成するパルスジェ ネレータを起動する周期イベントソー スを起動します。これは、トリガー信 号がアクティブになったときに両方の カードが完全に構成され、準備完了に なっている必要があるためです。

# 追加の測定機器

使用した追加機器:

- Stanford Research Systems CG635 (10MHzクロックリファレンス用)
- ・Agilent Technologies N5181A(信号 ソース用)

# 結果

# ■ タイムドメイン

Figure 30 は delay\_adjustmentcalibrationの前後のサンプリングされ た信号を示しています。



Figure 31は測定された時間誤差を示 しています。つまり、予想されるサン プリング周期の半分 (50ps) からの偏差、 異なる入力周波数で測定されたカード 間の時間差です。

- ・2つのチャネル間の時間誤差が4ps未 満で20GSPSに達します。
- ・GPUへのストリーミングと、最大 25.6GB/sの速度でのcupyでのデー タのインターリーブが測定されまし た。

# ■ 周波数ドメイン

2GHz でのテストトーンのFFTを Figure 32に示します。FFTには、2つ のADQ35のインターリーブによるイン ターリーブスプリアスが含まれていま す。インターリーブスプリアスは、時間(位相)、振幅、およびオフセットの 不一致によって発生します。Figure 33 には、オフセットと振幅のエラーが補 正された同じ信号が含まれています。 これは、時間誤差がインターリーブス プリアスに及ぼす影響です。

# リファレンスドキュメント:

Teledyne SP Devices社

Application Note : Interleaving 2 pieces of ADQ35 to get 20 GSPS and stream data to GPU



MISH Tech Journal 2025 SUMMER









# APPLICATION

# 分散型光ファイバーセンシング(DFOS)

# はじめに

光ファイバーは、データ伝送ネット ワークにおける古いツイストペア銅線 接続に代わる、私たちの世界をつなげ る最新の通信網として一般的に認識さ れています。しかし、光ファイバーに は独自の物理的特性があることから、 さまざまな分散型センシングアプリ ケーションに適しており、実際にその 用途が想定されています。光ファイバー の経済性と、長い距離にわたって局所 的な測定を行えるという本来の能力が 組み合わさったアプリケーションが、 その恩恵を受けています。計測方法は、 主に3つのセンシング手法に分けられ ます。

- 分散温度センシング (DTS)
- 分散音響センシング (DAS)
- 分散歪みセンシング (DSS)

光ファイバーケーブルは、集中した 光(レーザー、VCSEL、またはLED光源 から供給)を適度な減衰で長距離伝送 する導波管として機能します。信号を 伝送する場合、ファイバーは物理的に 小型・軽量であることの利点がありま す。さらに、電磁干渉の影響を受けま せん。

# 分散型光ファイバーセンシング (DFOS)の基礎

科学的には、製造中にファイバーに 不純物が生じると、ファイバーを通過 する光に低レベルの散乱が生じること が分かっています。散乱には3つの種 類(Figure 34)があり、その物理的特徴 と検出に必要な方法によって次のよう に説明されます。

光子の散乱はランダムな確率プロセ スです。散乱は弾性的(レイリー散乱な ど)であり、散乱された光子は同じ波長 を維持することを意味します。非弾性 ブリルアン散乱およびラマン散乱では、 散乱された光子は原子レベルでのエネ ルギーレベル遷移と連動して、かなり の波長シフトを経験します。波長の変 化は、波長が減少する場合はストーク スまたは反ストークスとして示されま す。

分散型光ファイバーセンシング (Figure 35)の基本操作では、コヒーレント光の 繰り返しパルスで光ファイバーを照射 する必要があります。使用する機器は インタロゲータ (Interrogator) と呼ば れます。各パルスはファイバーに沿っ て進むにつれて伝送遅延が発生します。 ファイバー全体の個々の位置で、大き く減衰した後方散乱信号(Backscatter) が発生し、その飛行時間によって決ま る既知の時間(伝搬遅延)で送出元に戻 ります。適切な光結合デジタル化シス テムで戻り経路信号をサンプリングす ることで、温度、機械的歪み、さらに音 響エネルギーなどの局所的な物理的特 性を検出でき、さまざまな経済的計測 アプリケーションを提供します。

# デジタイザを選択する際に 考慮すべき事項

DFOSアプリケーションの最も重要 な側面は、次の点を理解することです:

- 検出される特定のタイプに関係なく、 後方散乱 (Backscatter) は、低レベ ル信号で構成されているため検出す るのに高いダイナミックレンジが必 要です (ADC分解能:10ビット以上)。
- 光ファイバー計測に使用される短い 光パルス(通常5ns~20µs)は、そ れらを効果的にキャプチャするため に高速デジタイザが不可欠であるこ とを意味します。したがって、数ギ ガサンプル(GSPS)のサンプルレー トが必要になる場合があります。
- 適切な測定パルス幅の選択は、ファ イバーの長さを考慮しパルスの飛行 時間を評価することによって決定さ れます。
- DFOSシステム設計者は、選択したデジタイザが提供する高パフォーマンスを補完するため、適切な光フロントエンドパルス生成および検出回路の設計にも注意を払う必要があります。

リファレンスドキュメント: Teledyne SP Devices社 Application Note:Interleaving 2 pieces of ADQ35 to get 20 GSPS and stream data to GPU







# 新製品ピックアップ

# ここでは今年の新製品をピックアップして紹介します。

- SPECTRUM社製 M5i.6357-x16 10GSPS高速D/Aボード
- Alpha Data社製 ADM-XRC-9R1-B RFSoC搭載FPGAボード
- Teledyne SP Devices社製 ADQ35-WB 10GSPS広帯域A/Dボード
- Daqscribe社製 DDR7400 400Gbps イーサネットデータレコーダ
- Daqscribe社製 RDR4050 MIL規格対応 耐環境イーサネットレコーダ

# SPECTRUM社製 M5i.6357-x16 10GSPS高速D/Aボード



M5i.6357-x16 は、10GS/s の D/A コ ンバータを搭載した任意波形ジェネ レータ(AWG)ボードです。 サンプリ

# Alpha Data社製 ADM-XRC-9R1-B RFSoC搭載FPGAボード



ADM-XRC-9R1-B は、AMD Zync UltraScale+ RFSoC (5GHz AD & 10GHz DA内蔵)を搭載した XMCタイ プの FPGA ボードです。8chの5GSPS





ADQ35-WBは、10GHz 12bit 1ch (又 は5GHz 12bit 2ch)のサンプリングレー トで最大9GHzのアナログ入力帯域幅 を備えた広帯域の高速A/Dボードです。



| M5i.6357-x16 仕様 |                           |
|-----------------|---------------------------|
| サンプリングレート       | 10GSPS, 5GSPS             |
| 出力チャンネル数        | 1CH, 2CH                  |
| 分解能             | 16bit                     |
| 帯域幅             | 2.5GHz                    |
| フォームファクタ        | PCI Express Gen3, x16 レーン |
| 温度範囲            | $0 \sim +50^\circ C$      |
| OS              | Windows, Linux            |

ングレートは1chで10GS/s、2chで 5GS/sをサポートし、16bitの分解能を 備えているため速度と分解能の両方で 最高のパフォーマンスを提供します。 また、オプションのStar-Hubを使用す ることで最大16chを同期することがで きます。超音波、レーダ、LiDAR、無線 通信、レーザ、加速器、非破壊検査など のアプリケーションに適合します。 Windows又はLinux対応。

| ADM-XRC-9R1-B 仕様 |                                                   |
|------------------|---------------------------------------------------|
| A/D コンバータ        | 5GSPS, 14bit, 8ch                                 |
| D/A コンバータ        | 10GSPS, 14bit, 8ch                                |
| FPGA             | Zynq UltraScale+: XCZU47DR-2 または XCZU48DR-2       |
| ARMコア            | 4x ARM Cortex-A53 MPCore, 2x ARM Cortex-R5 MPCore |
| フォームファクタ         | XMC                                               |
| 温度範囲             | $-40 \sim +70^\circ C$                            |
| OS               | Windows, Linux                                    |

ADコンバータ及び8chの10GSPS DA コンバータをRFSoCチップに内蔵して います。FPGA はユーザプログラム可 能で、ユーザロジックを実装すること が可能です。耐環境仕様としてコンダ クションクールをサポートしています。 ソフトウェアドライバは Windows, Linuxが用意されており、レーダ・画像 処理・ソフトウェア無線機・5Gアプリ ケーションに最適です。

| ADQ35-WB 仕様 |                                   |
|-------------|-----------------------------------|
| サンプリングレート   | 10GSPS, 5GSPS                     |
| チャンネル数      | 1DH, 2CH                          |
| 分解能         | 12bit                             |
| 帯域幅         | 2.5GHz                            |
| メモリ         | 8GB SDRAM                         |
| フォームファクタ    | PCI Express Gen3, x16 $ u$ – $ u$ |
| 温度範囲        | $0 \sim +55^{\circ}$              |
| OS          | Windows, Linux                    |

Kintex UltraScale FPGA を搭載してお り、カスタムのリアルタイムデジタル 信号処理 (DSP) に十分なリソースを提 供します。最大14 Gbyte/s の速度でピ アツーピアストリーミングをサポート し、GPU、CPUまたはSSDへの効率的 なデータ転送を可能にします。LIDAR、 ビーム位置モニター、高エネルギー物 理科学の用途に適しています。





DDR7400は、400GbEをサポートし たイーサネットインタフェースのデー タレコーダです。記録容量は最大 360TBを搭載する事ができます。入出 カインタフェースはリンクオプション でSFP+(10GbE)からQSFPDD (400GbE) の光ポートを選択することができます。 ストレージはNVMeタイプのSSDを採 用しており、30TB ~ 360TBまで選択す ることができます。オプションで FPGA データ処理を追加することがで きます。100% イーサネットキャプチャ、 記録/再生をサポート。19インチラッ クマウントタイプでOSはLinuxを搭載 しています。レーダや広帯域無線信号 の記録・再生アプリケーションに最適 です。

| DDR7400 仕様 |                                                |
|------------|------------------------------------------------|
| インタフェース    | 400Gb, 200Gb, 100Gb, 40Gb, 25Gb, 10Gb Ethernet |
| ストレージ容量    | 360TB                                          |
| タイプ        | 1U ラックマウント                                     |
| 温度範囲       | $0 \sim +35^{\circ}$                           |
| OS         | Linux                                          |

# Daqscribe社製 RDR4050 MIL規格対応 耐環境イーサネットレコーダ



RDR4050は、MIL規格に対応した耐 環境仕様のイーサネットデータレコー ダです。記録容量は最大120TBを搭載 する事ができます。入出力インタフェー スはリンクオプションでSFP+(10GbE) からQSFP+(40GbE)の光ポートを選択 することができます。ストレージは NVMeタイプのSSDを採用しており、 7TB~120TBまで選択することができ ます。

データオフロードオプションにより 高速データ転送が可能です。温度範囲 は-40 ~ +60℃をサポートしており、 MIL-STD-810に準拠しています。航空 機や回転翼に搭載してご利用いただく ことができます。 レーダや広帯域無線 信号の記録・再生アプリケーションに 最適です。

| RDR4050 仕様 |                           |
|------------|---------------------------|
| インタフェース    | 50Gb, 25Gb, 10Gb Ethernet |
| ストレージ容量    | 120TB                     |
| タイプ        | 耐環境ボックス                   |
| 温度範囲       | -40 $\sim$ +60°C          |
| OS         | Linux                     |

# 地球温暖化を考える3



ドナルド・トランプ氏がアメリ カの第47代大統領になってか ら、パリ協定から離脱してしまい ました。

世界の二酸化炭素排出量の約 13%を排出しているアメリカが パリ協定から離脱したことで 「2050年カーボンニュートラル」 の実現は困難になるでしょう。 少なくともトランプ氏が大統領 である任期中は13%が減少方向 になることは無さそうですね。 このアメリカの決定を受けて中 国も離脱しないか心配です。

地球温暖化は現在も進行してい ますが、少しでもその上昇を抑え る為に私達は日々の生活で心が ける必要があります。つい忘れ てしまいがちですが、もう一度日 常を見直してみましょう。

- 冷房を1℃高く、暖房を1℃
   低く設定する
- 長時間停車時はエンジンを切る
- 炊飯器の保温を止める
- 風呂の残り湯を洗濯に使う
- 家族が同じ部屋で過ごす

● TVの視聴時間を1時間減らす 少し不便になるかもしれません が、昔の人は不便な生活でも知恵 を使って楽しく暮らしていたの です。

# 展示会のご案内

DSEI Japan 日時: 2025年5月21~23日 場所:幕張メッセ 皆様のご来場をお待ちしています。

# 受託開発

弊社ではソフトウェア / ハードウェ ア /FPGA の受託開発も承ってお ります。お困りの事がございまし たらお気軽にご相談ください。 ⊠ sales@mish.co.jp

# おわりに

テックジャーナルでは、これからも 出来る限りお客様に有効となる情 報を提供していきたいと思います。 今後ともどうぞよろしくお願いい たします。

# NOVO SPACE

# *∎ #:*₽}

◆ Plug & Playで複数のH/Wを組み合わせることで開発期間を短縮します

# 

◆ 最先端の部品と高速インタフェースで高性能化を実現します

# <u>▋;</u>〗=<u>╡</u>╡<u><u>ਗ਼</u><u></u>;<u></u>];<u>]</u> ╡</u>:

◆ 共有バスを使用していないため障害が他の基板に波及しません

# 

◆ 独自の特許技術で体積を最大35%節約します

# OPINSIANDARD

◆ 標準規格(SpaceVPX)を採用しています



