Closネットワーク
電気通信の分野において、Closネットワーク(クロス・ネットワーク)とは、マルチステージの回路交換ネットワークの一種であり、実用的なマルチステージのスイッチングシステムの論理的な理想形を表したものである[1]。1938年にEdson Erwinが発明し、1952年にCharles Clos(フランス語発音: [ʃaʁl klo])によって初めて形式化された[2]。
複数のステージを加えることにより、Closネットワークは大規模なクロスバースイッチを構成するために必要な交差点を削減している。Closネットワークのトポロジー(下にダイアグラムを示す)は、3つの整数でパラメタ化されている。は ingressステージの各クロスバースイッチ(crossbar switch)への入力の数を表し、は ingressステージの各クロスバースイッチの出力の数を表す。ingressステージにはクロスバースイッチが個あり、middleステージのクロスバースイッチの数はである。
回路のスイッチングにより、接続の間だけ持続するエンドポイントとエンドポイントを接続する1つの通信経路が形成される。この方法では、接続された経路の利用率が低い場合、利用可能な総バンド幅が無駄になる。しかし、接続とバンド幅はより予測可能なものになり、そして、現代的なパケットスイッチングネットワークがパケットのハンドリングのたびに制御が必要であるのに対して、Closネットワークでは、接続の初期段階での制御のオーバーヘッドしか必要としない。
Closネットワークが最初に考案されたときは、クロスポイントの数は、スイッチングシステムの総コストによく近似できた。この事実は電気機械式クロスバーには重要だったが、相互接続を直接シリコンに実装することが可能であるVLSIの出現や、比較的小さなボードのクラスタには不要であったため、重要性は薄れていった。ところが、光ファイバーの接続をベースとした非常に大規模な相互接続構造を持つ複雑なデータセンターの出現によって、Closネットワークは再び重要性を取り戻した[3]。 Closネットワークの一種であるBenešネットワークは、近年の応用先として機械学習での利用を見い出した[4]。
トポロジー
編集Closネットワークには3つのステージがある。すなわち、ingressステージ、middleステージ、egressステージの3つである。各ステージは、複数のクロスバースイッチから構成され(下の図を参照)、それらはしばしば単にクロスバー(crossbars)と呼ばれる。ingressのクロスバースイッチに入力される呼び出し(call)は、それぞれ任意の利用可能なmiddleステージのクロスバースイッチを経由して、対応するegressステージのクロスバースイッチにルーティングされる。ある新しい呼び出しに対して利用できるmiddleステージのクロスバーは、middleステージのスイッチからegressステージのスイッチに接続されたリンクがフリーである場合のみである。
Closネットワークは3つの整数 によって定義される。 は、 個あるingressステージの各クロスバースイッチへの入力の数を表す。各ingressステージのクロスバースイッチには 個の出口があり、middleステージには 個のクロスバースイッチがある。ingressステージの各スイッチとmiddleステージの各スイッチの間の接続は、ちょうど1本である。egressステージには 個のスイッチがあり、それぞれのスイッチは 個の入力と 個の出力を持っている。middleステージの各スイッチは、egressステージの各スイッチとちょうど1本で接続されている。したがって、ingressステージには 個のスイッチがあり、そのそれぞれは 個の入力と 個の出力を持つ。middleステージには 個のスイッチがあり、そのスイッチのそれぞれは、 個の入力と 個の出力を持つ。egressステージには 個のスイッチがあり、そのそれぞれは 個の入力と 個の出力を持つ。
ブロッキング特性
編集と という相対的な値は、Closネットワークのブロッキング特性を定めている。
3つ以上のステージを持つClosネットワーク
編集Closネットワークは奇数個のステージに一般化することが可能である。中央のステージの各クロスバースイッチを3-ステージのClosネットワークで置き換えれば、5ステージのClosネットワークを構成することができる。同じ手順を繰り返せば、7, 9, 11, …段階のステージを作れる。
Benešネットワーク(m = n = 2)
編集m = n = 2 であるとき、このタイプのネットワークはBenešネットワークと呼ばれる。
入力および出力の数が N = r×n = 2r である場合、ネットワークは 2log2N − 1 個のステージからなる。各ステージは N/2 個の 2×2 クロスバースイッチからなり、全部で N log2N − N/2 個の 2×2 クロスバースイッチがある。例えば、8×8 Benešネットワーク(つまり、N = 8 の場合)は、下図に示すように、2 log2 8 − 1 = 5 個のステージを持ち、各ステージには N/2 = 4 個の 2×2 クロスバースイッチがあり、全部で Nlog2N − N/2 = 20 個のスイッチが使われる。内側の3つのステージは2つの小さい 4×4 Benešネットワークになっており、 中央のステージにおいては、各2×2のクロスバースイッチそのものが 2×2 Benešネットワークを構成している。この例は、このタイプのネットワークの再帰的な構造を良く表している。
関連項目
編集- クロスバースイッチ Closネットワークのスイッチ要素について説明している。
- Nonblocking minimal spanning switchClosネットワークのスイッチングアルゴリズムについて説明している。
- Banyan switch別のネットワーク構成方法の1つ。
- Fat tree別のネットワーク構成方法の1つ。
- Omega network別のネットワーク構成方法の1つ。
出典
編集- ^ US patent 2244004
- ^ Clos, Charles (Mar 1953). “A study of non-blocking switching networks”. Bell System Technical Journal 32 (2): 406–424. doi:10.1002/j.1538-7305.1953.tb01433.x. ISSN 0005-8580 22 March 2011閲覧。.
- ^ Hogg (2014年1月11日). “Clos Networks: What's Old Is New Again”. Network World. 2018年11月1日閲覧。
- ^ Moore (31 October 2018). “Flex Logix Says It Has Solved Deep Learning's DRAM Problem”. spectrum.ieee.org. IEEE Spectrum. 1 November 2018閲覧。