**PASJ2018 THP097** 

# cRIO を用いたパルスマグネット用インターロックシステムの開発 DEVELOPMENT OF INTERLOCK SYSTEM FOR PULSE MAGNET USING CRIO

牛本信二<sup>#, A)</sup>, 榎本嘉範<sup>B)</sup> Shinji Ushimoto <sup>#, A)</sup>, Yoshinori Enomoto <sup>B)</sup> <sup>A)</sup> Mitsubishi Electric System & Service Co.,Ltd. <sup>B)</sup> KEK

#### Abstract

We have made up interlock system for pulse magnet with CompactRIO(cRIO). The cRIO is a combination of a realtime controller, reconfigurable IO Modules (RIO), FPGA module and an Ethernet expansion chassis. By using the FPGA, we achieved the high stability and reliability required for the interlock system. In addition, we built an EPICS server on realtime OS to create a highly available system. We have been developing this system since last year, and now we are progressing on improvement step by step while conducting a long-term test.

#### 1. はじめに

KEK 電子陽電子入射器(以下、入射器)では Energy の異なる 5 つの蓄積リング(PF.PF-AR、SuperKEKB HER/LER および陽電子ビーム用ダンピングリング [DR])への同時入射に向けたビームラインと制御機器の 更新[1]を進めている。Figure 1 に入射器の構成を記す。 入射器は 2 種類の電子銃を備えた 2 階建て構造の入射 部、S-band 加速管 4 本からなるおよそ 10m 長の加速ユ ニットが 4~8 ユニットで構成される 8 つのセクター、二つ の直線部を結ぶ 180 度偏向部、ビームの振り分けをおこ なうスイッチャードで構成される。

電子銃から出射された電子ビームは一様に2セクター まで加速されたのち、Energyの異なる下流のリングに向 けて3セクター以降で加減速をおこなう。また、1セクター に設置された陽電子標的で生成された陽電子ビームは、 2セクター下流に配置された第2ビームスイッチヤードか らDR へ入射、取り出したビームを3セクターに戻して再 度加速をおこなう。



Figure 1: Layout of KEK LINAC.

このようなビーム切り替えにおいて、最適なビーム輸送 を実現するため、四極電磁石およびステアリング電磁石 を DC からパルスへ交換した。

この変更に伴い、新たにパルスマグネットの制御シス テムを構築[2]し運用をおこなっている。Figure 2 にパル スマグネット制御システムを記す。

本稿ではこの制御システムにおけるインターロックシステムについて紹介する。



Figure 2: Pulse magnet control system.

#### 2. cRIO 導入の経緯

入射器では RF 源のモジュレータや運転用安全系イン ターロックシステム等に多くの PLC(Programble Logic Contoroller)を使用されており、電磁石電源制御システム も PLC を中心に構築されていた。これらのシステムで使 用されてきた PLC は、長期間に渡って高い安定性を実 現していたが、近年の Gigabit Ethernet に見られるネット ワークの高度化や、制御システムの EPICS[3]対応などに 機器の更新が追いついていない状況となっていた。

近年、FPGAを搭載した組込み機器などが複数のメー カーから発表され、PLC に代わるシステム構築のベース として注目されている。新たに開発したパルスマグネット 制御システムでは従来の電磁石電源とは全く異なる制御 方法となるため、インターロックに関しても、高安定性、高 堅牢性を備え、かつ汎用性の高い新しいシステムを目指 して開発をおこなうこととなった。その過程で、National Instruments 社の CompactRIO[4](以下、cRIO)に着目 し、これをベースとして新しインターロックシステムを構築 することとした。Figure 3 に使用した cRIO ユニットを記す。

<sup>#</sup> ushimoto@post.kek.jp

Proceedings of the 15th Annual Meeting of Particle Accelerator Society of Japan August 7-10, 2018, Nagaoka, Japan

#### **PASJ2018 THP097**



Figure 3: cRIO unit.

cRIO は従来の PLC に対して以下のような優位性があ り、尚且つ SuperKEKB 真空グループでの導入、長期運 転使用実績などを考慮し、選定した。

- Linux OS 搭載により EPICS 環境の構築が可能
- FPGA による CPU に依存しない信頼性の高いロジック判定と動作
- HDL (hardware description language)を必要せず、 LabVIEW[5]による FPGA 開発が可能

## 3. インターロックシステム

従来の電磁石電源は、電源内部の異常(過電圧、過 電流および内部の異常発熱)と電磁石側の異常(コイル に取り付けた温度スイッチと冷却水のフロースイッチ)を 外部インターロックとして、電源内で完結した処理をおこ なっていた。電磁石制御においては、PLC は一部の例 外を除き、インターロック用の機器としては使用していな かった。

一方、新しいパルスマグネットの制御システムは、独自 に発したパルスドライバーを中心に複数の機器で構成さ れている。そのため、従来の電磁石電源に比べて多くの 信号を処理する必要がある。Figure 4 にインターロックシ ステムの概要、Table 1 に使用した cRIO ユニットの構成 を記す。



Figure 4: Overview of interlock system.

Table 1: Construction of cRIO Unit

| NI cRIO-9063 | 667 MHz Dual-Core CPU, 256 MB<br>DRAM, 512 MB Storage, Zynq-7020<br>FPGA, 4-Slot CompactRIO Controller |
|--------------|--------------------------------------------------------------------------------------------------------|
| NI 9403      | 5 V/TTL, 32 Bidirectional Channels,<br>7 μs C Series Digital Module                                    |
| NI 9205      | $\pm$ 10 V, 250 kS/s, 16-Bit, 32-Channel<br>C Series Voltage Input Module                              |
| NI 9402      | 4-Channel, SPST Relay, 60 VDC (1 A) /<br>250 VAC (1.5 A) C Series Relay Output<br>Module               |

温度センサなどのアナログ電圧信号は電圧入力モジュール(NI 9305)に接続する。一方、電磁石のコイル部に取り付けた温度スイッチなどの接点信号は、いったん Level Convertor Box でデジタル信号(5V/TTL)に変換した後、デジタル入力モジュール(NI 9403)に接続する。これらの信号は全て FPGA で演算およびロジック処理をおこなう。

インターロック信号となる接点出力は cRIO のリレーモ ジュール(NI 9402)から充電用電源のシャットダウン入力 に接続されている。インターロック作動時はこの接点が OPEN となることで充電電源が OFF される。その結果、 パルスドライバーの充電が停止し、マグネットへの通電が 止まる仕組みとなっている。

## 4. cRIO ソフトウェア

cRIO は搭載する FPGA と RealTimeOS (以下、RT)を 同じ LabVIEW プロジェクトで管理しプログラミングをおこ なう。今回のシステムでは LabVIEW 2016 を使用した。 LabVIEW では個々のプログラムを VI (Virtual Instruents) と呼ぶため、以下ではそれぞれのプログラムを FPGA VI、 RT VI と称する。

Figure 5は cRIO 上における FPGA VI とRT VI の関係についての模式図である。FPGA VI では主に各モジュールの入力信号処理と、インターロック信号に使用するリレーモジュールの出力制御などのハードウェア処理をおこなう。一方、RT VI では EPICS Server の実装や、FPGA VI で使用する変数の管理などのソフトウェア処理をおこなっている。以下に、各 VI の詳細とパラメータの設定、管理方法について記す。



Figure 5: Relation of VI and EPICS Server.

#### **PASJ2018 THP097**

#### 4-1. FPGA VI

cRIO 上の FPGA は RT から直接 I/O として FPGA を 制御するスキャンモードと FPGA 単体で動作可能な FPGA モードを有する。今回のシステムでは高信頼性を 得るため、RT の影響を受けない FPGA モードでの開発 をおこなった。

アナログ入力信号(AI)の処理では、移動平均とス ケーリングを行ったのち、ch ごとに変数として定義した閾 値(HIGH/LOW)に対して TRUE(範囲内)、FALSE(範 囲外)の判定をおこなう。一方、デジタル入力信号(DI) に関しては、信号の HIGH/LOW に応じて、 TRUE/FALSEの値を返す。

これら FPGA VI 内で算出した値と各変数は、全て VI 上の GUI(表示器および制御器)に格納している。FPGA VI 上の GUI は変数として RT VI から参照できるため、 開発目標であった FPGA VIの再ビルドを必要とせずに、 外部から FPGA 上の閾値やロジックの変更が可能なシス テムが構築できた。

## 4-2. RT VI

入射器制御システムのベースである EPICS と連携す るため、RT VI では LabVIEW 付属の EPICS I/O Server[6]機能を用い、cRIO 上に CA Server を構築した [7,8]。

この CA Server は EPICS の PV (Process Variable)の デプロイをおこなったのち、LabVIEW のネットワーク変数 であるシェア変数 (Shared Variable)と PV をバインドする。 これにより、EPICS からは PV 経由、VI から直接シェア変 数を参照することができる。シェア変数を動的に宣言す るには LabVIEW DSC モジュールが必要となるが、残念 ながらこの機能は cRIO の NI Linux 上ではサポートされ ておらず、必要な変数は事前にプロジェクトファイル内で 用意し、VI のビルド時に都度デプロイをおこなう必要が ある。

#### 4-3. パラメータ設定パネル

インターロックに使用するパラメータは cRIO 毎に数百 点に及ぶ。直感的かつ容易にこれらの設定をおこなうた め専用の VI を作成し使用している。Figure 6 に設定パ ネルを記す。このパネルでは AI/DI の ch 毎にインター ロック出力の有無をマスクで設定する。マトリックス構造を 採用したことで、出力に対応した入力信号が一目瞭然と なり、設定ミスなどが軽減した。



Figure 6: Matrix mask setting panel.

#### 4-4. パラメータ管理

各 cRIO 上には PV 自動生成用 (pvlist.csv) とパラメー タ自動設定 (lastdata.csv)の2 種類のファイルを使用して パラメータ管理をおこなう。

電源投入後、最初に FPGA VI が起動する。FPGA VI にはファイル I/O が無いため、この段階ではパラメータの 設定はおこなわれない。次に RT VI が起動すると、まず pvlist.csv を読み込み、PV の生成をおこなう。EPICS Server の正常起動確認後、lastdata.csv を読み込みパラ メータの設定が完了する。

通常動作時に EPICS 経由でパラメータの変更した際 は、RT VI 上で lastdata.csv の書き換えをおこない、常に 最新のパラメータを保持している。

## 5. システムの運用状況

運用開始時にはいくつかのバグがあったが、修正後 は問題なく連続稼働している。しかし3カ月を過ぎたあた りで、一部の個所で RT VI が止まる現象が見られた。そ の際、電源の off/on にて復旧し、その後2カ月間問題な く現在まで連続稼働している。さらなる長期安定運転へ 向けて現在原因を調査している。

# 6. 今後の課題

長期連続動作時に発生する RT VI のフリーズ原因を 特定する必要がある。また、RT VI の EPICS Server で宣 言した PV には、EPICS 標準のアラーム機能が未対応で あるため、レコード監視のための新たな仕組みを組み込 む必要がある。

これらの問題を解決し、更なる長期安定稼働を実現す るため今後もシステム開発を継続する。

# 参考文献

- [1] Y. Seimiya *et al.*, "KEK 電子陽電子入射器の現状", Proceedings of the 15th Annual Meeting of Particle Accelerator Society of Japan, Nagaoka, Japan, Aug. 7-9, 2018.
- [2] Y. Enomoto *et al.*, "A NEW PULSED MAGNET CONTROL SYSTEM IN THE KEK ELECTRON POSITRON LINAC", IPAC2018, Vancouver, Canada, Apr 29 - May.4, 2018.
- [3] Experimental Physics and Industrial Control System; https://epics.anl.gov/
- [4] National instruments CompactRIO システム; http://www.ni.com/ja-jp/shop/compactrio.html
- [5] LabVIEW;
- http://www.ni.com/ja-jp/shop/labview.html [6] LabVIEW EPICS;
- http://www.ni.com/white-paper/14144/en/
- [7] Creating EPICS Server I/O Servers (DSC Module or Real-Time Module); http://zone.ni.com/reference/en-XX/help/370622P-
- 01/lvmve/create\_epics\_s\_serv/
  [8] Using EPICS Server I/O Servers (DSC Module or Real-Time Module); http://zone.ni.com/reference/en-XX/help/370622P-

01/lvmve/using\_epics\_s\_serv/