JP3995594B2 - ネットワーク経由でデータチャネルをコントローラにデジタル方式でインターフェイスするためのネットワーク・デバイス・インターフェイス - Google Patents
ネットワーク経由でデータチャネルをコントローラにデジタル方式でインターフェイスするためのネットワーク・デバイス・インターフェイス Download PDFInfo
- Publication number
- JP3995594B2 JP3995594B2 JP2002548925A JP2002548925A JP3995594B2 JP 3995594 B2 JP3995594 B2 JP 3995594B2 JP 2002548925 A JP2002548925 A JP 2002548925A JP 2002548925 A JP2002548925 A JP 2002548925A JP 3995594 B2 JP3995594 B2 JP 3995594B2
- Authority
- JP
- Japan
- Prior art keywords
- data
- message
- data channel
- ndi
- network
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Expired - Lifetime
Links
- 230000001360 synchronised effect Effects 0.000 claims description 95
- 238000000034 method Methods 0.000 claims description 30
- 230000007704 transition Effects 0.000 claims description 16
- 230000004044 response Effects 0.000 claims description 12
- 238000006243 chemical reaction Methods 0.000 description 18
- 230000003750 conditioning effect Effects 0.000 description 18
- 230000005540 biological transmission Effects 0.000 description 17
- 230000006870 function Effects 0.000 description 17
- 238000010586 diagram Methods 0.000 description 16
- 238000004891 communication Methods 0.000 description 13
- 238000012544 monitoring process Methods 0.000 description 10
- 230000008901 benefit Effects 0.000 description 9
- 230000008859 change Effects 0.000 description 9
- 238000005259 measurement Methods 0.000 description 8
- 230000008569 process Effects 0.000 description 8
- 230000009471 action Effects 0.000 description 6
- 238000012360 testing method Methods 0.000 description 5
- 239000003990 capacitor Substances 0.000 description 4
- 230000015556 catabolic process Effects 0.000 description 4
- 238000006731 degradation reaction Methods 0.000 description 4
- 238000012546 transfer Methods 0.000 description 4
- 230000001133 acceleration Effects 0.000 description 3
- 230000000630 rising effect Effects 0.000 description 3
- 238000005070 sampling Methods 0.000 description 3
- 238000005260 corrosion Methods 0.000 description 2
- 230000007797 corrosion Effects 0.000 description 2
- 230000001934 delay Effects 0.000 description 2
- 238000011161 development Methods 0.000 description 2
- 230000000694 effects Effects 0.000 description 2
- 238000000605 extraction Methods 0.000 description 2
- 238000012986 modification Methods 0.000 description 2
- 230000004048 modification Effects 0.000 description 2
- 238000005452 bending Methods 0.000 description 1
- 230000003247 decreasing effect Effects 0.000 description 1
- 238000001514 detection method Methods 0.000 description 1
- 230000007613 environmental effect Effects 0.000 description 1
- 230000005284 excitation Effects 0.000 description 1
- 230000006855 networking Effects 0.000 description 1
- 238000011084 recovery Methods 0.000 description 1
- 238000011160 research Methods 0.000 description 1
- 238000013519 translation Methods 0.000 description 1
- 230000001960 triggered effect Effects 0.000 description 1
Images
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L12/00—Data switching networks
- H04L12/28—Data switching networks characterised by path configuration, e.g. LAN [Local Area Networks] or WAN [Wide Area Networks]
- H04L12/40—Bus networks
- H04L12/40006—Architecture of a communication node
- H04L12/40032—Details regarding a bus interface enhancer
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L12/00—Data switching networks
- H04L12/28—Data switching networks characterised by path configuration, e.g. LAN [Local Area Networks] or WAN [Wide Area Networks]
- H04L12/40—Bus networks
- H04L12/407—Bus networks with decentralised control
- H04L12/413—Bus networks with decentralised control with random access, e.g. carrier-sense multiple-access with collision detection [CSMA-CD]
- H04L12/4135—Bus networks with decentralised control with random access, e.g. carrier-sense multiple-access with collision detection [CSMA-CD] using bit-wise arbitration
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L25/00—Baseband systems
- H04L25/38—Synchronous or start-stop systems, e.g. for Baudot code
- H04L25/40—Transmitting circuits; Receiving circuits
- H04L25/49—Transmitting circuits; Receiving circuits using code conversion at the transmitter; using predistortion; using insertion of idle bits for obtaining a desired frequency spectrum; using three or more amplitude levels ; Baseband coding techniques specific to data transmission systems
- H04L25/4904—Transmitting circuits; Receiving circuits using code conversion at the transmitter; using predistortion; using insertion of idle bits for obtaining a desired frequency spectrum; using three or more amplitude levels ; Baseband coding techniques specific to data transmission systems using self-synchronising codes, e.g. split-phase codes
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L12/00—Data switching networks
- H04L12/28—Data switching networks characterised by path configuration, e.g. LAN [Local Area Networks] or WAN [Wide Area Networks]
- H04L12/40—Bus networks
- H04L2012/40208—Bus networks characterized by the use of a particular bus standard
- H04L2012/40215—Controller Area Network CAN
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L12/00—Data switching networks
- H04L12/28—Data switching networks characterised by path configuration, e.g. LAN [Local Area Networks] or WAN [Wide Area Networks]
- H04L12/40—Bus networks
- H04L2012/40267—Bus for use in transportation systems
- H04L2012/4028—Bus for use in transportation systems the transportation system being an aircraft
Landscapes
- Engineering & Computer Science (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Physics & Mathematics (AREA)
- Spectroscopy & Molecular Physics (AREA)
- Information Transfer Systems (AREA)
- Small-Scale Networks (AREA)
- Selective Calling Equipment (AREA)
- Communication Control (AREA)
- Synchronisation In Digital Transmission Systems (AREA)
Description
【連邦政府の支援を受けた研究または開発】
この発明は、NASAによって与えられた協力協定番号第NCCW−0076号のもとに政府の支援を受けて行なわれた。政府は、この発明に或る権利を有する。
【0002】
【関連出願への相互参照】
この出願は、2000年12月8日出願の「ネットワーク経由でデータチャネルをコントローラにデジタル方式でインターフェイスするためのネットワーク・デバイス・インターフェイス(NETWORK DEVICE INTERFACE FOR DIGITALLY INTERFACING DATA CHANNELS TO A CONTROLLER VIA A NETWRK)」と題される米国仮特許出願連続番号第60/254,136号からの優先権を主張し、その内容をここに引用により援用する。
【0003】
【発明の分野】
この発明は一般に、ネットワーク・デバイス・インターフェイスに関し、特に、共通のネットワークバス上でデータチャネルをコントローラにデジタル方式でインターフェイスするための装置および方法に関する。
【0004】
【発明の背景】
今日多くの産業において、システム故障の可能性、または関心のあるオブジェクトに対する環境およびその他の外部的な力の影響の評価を行なうためにモニタリングシステムが使用されている。たとえば、航空電子業界では、モニタリングシステムは、航空機上のさまざまな重要な構造的な場所における、歪み、加速度、圧力、腐食および温度などのパラメータを監視するために用いられている。同様に、そのようなモニタリングシステムは、オン/オフ乗員制御から動力伝達経路制御およびマルチメディアシステムに至るまで、あらゆるものを制御および監視するために自動車業界でも使用することができる。
【0005】
これら従来のモニタリングシステムの多くは、重要な場所で監視されているオブジェクトのまわりに位置付けられる、センサ、アクチュエータおよびサブシステムなどの複数の遠隔デバイスを使用する。さらに、これら従来のモニタリングシステムの多くは、遠隔デバイスからのデータを受取りかつ遠隔デバイスにコマンドを送信するために、遠隔デバイスの各々に接続される1つまたはいくつかのコントローラを含む。作動中、コントローラはさまざまなセンサからデータを取得する。コントローラは、オブジェクト上で機能を実現するためにアクチュエータの作動も行なう。
【0006】
これら従来のモニタリングシステムは、オブジェクトの重要な構造を監視するための方法を提供するが、いくつか欠点がある。たとえば、従来のモニタリングシステムの多くは、遠隔デバイスの各々をコントローラに接続するために専用の配線および信号調整を使用する。さらに、通常、遠隔デバイスの多くはアナログ方式であり、通常、遠隔デバイスから受取られるデータはアナログの形である。
【0007】
航空電子業界および自動車業界を含め、今日多くの業界では、ネットワークの複雑さによって、いくつかの理由のため、従来のモニタリングシステムは非実用的なものになり得る。特に、専用の配線および信号調整は、高価で、かさばり、重く、しかも設置および維持が難しくなり得る。これは、重量およびサイズを第1に考慮する航空機での応用において、特に重大な意味を持つ。さらに、自動車業界では、配線の追加は自動車の重量とコストを増やし得る。
【0008】
さらに上述のように、多くの従来のモデリングシステムは、アナログフォーマットでデータを伝送する。通常、アナログ信号は、データ伝送中に信号に取込まれる雑音の影響を受けやすい。伝送される信号の多くは、開始の振幅が低いため、この雑音は、信号を劣化させ、信号の解像度の損失を引起こす信号対雑音比を低下させる。さらに、これら遠隔デバイスの多くは、コントローラからかなりの距離の所に散在するため、遠隔デバイスをコントローラに接続する電気線が、配線内のDC抵抗による信号劣化を引起こすほどに長くなり得る。
【0009】
このことを考慮すると、専用の配線およびアナログ伝送を共通のバスで置き換え、データのデジタル伝送を使用することが有利であろう。しかし、多くの従来のデジタルネットワークには、それ自身にさまざまな問題がある。たとえば、多くの既存のデジタルネットワークは、プロセッサを必要とし、かつ受容できないほどの大きいまたは費用のかかる遠隔デバイスを強要する、複雑なプロトコルを必要とする。プロセッサベースの検出装置も、正確に、正しい時間にアナログデータをサンプリングする際、またはアクチュエータに動作を行なわせる際に問題を有し得る。また、複雑なプロトコルは、データ取得および制御に必要のないオーバーヘッドをバス上のメッセージに取込む。このオーバーヘッドによって、バス上で伝送可能なデータサンプルの数が大きく制限されることがある。これらのネットワークには他にも問題がある。たとえば、通常、それらは、取得および制御の両方をサポートせず、通常、短いネットワークのみをサポートする。さらに、これら従来のネットワークは、大抵、かさばるネットワーク・デバイス・インターフェイスを有し、ネットワークデータレートは遅く、またはネットワーク装置数が少ない。これに加えて、デジタルネットワークを含む多くのコンピュータシステムは、時間で決定された態様で作動しない。一般に、これらコンピュータシステムは、何らかの正しいタイミングで繰返しまたは解釈され実行される、ネットワーク構成要素へのトリガコマンドをスケジュールする能力に欠ける。
【0010】
上述のことを考慮すると、ネットワーク構成要素が、安価、単純かつ高速でありながら堅牢なネットワーク線上でデジタル形式で通信するのを可能にし、プロトコルが単純でオーバーヘッドメッセージが少なく、構成要素のサイズが小さく、しかも配線数の少ない、ネットワークシステムを提供すれば有利であろう。さらに、ネットワークシステムが、ネットワーク・デバイス用のマイクロコントローラまたはプロセッサを使用せずに作動すれば有利であろう。また、このネットワークシステムは、取得および制御の両方をサポートし、ネットワークに接続された複数の構成要素から同時にデータを取得または変換することができる。さらに、このネットワークシステムは、多くの構成要素、より長いネットワーク線を可能にし、正確な態様で時間決定性を保証する。
【0011】
【発明の概要】
理解を促し、この明細書での混乱を避けるため、ここでネットワークオブジェクトについて簡単に定義することが必要である。定義すべき第1のネットワークオブジェクトはバスコントローラである。バスコントローラは、ネットワークバス上でコマンドを送信するネットワーク・デバイスである。ネットワーク上の他のすべてのデバイスは、バスコントローラを聴き、バスコントローラのコマンドに基づいて動作を行なう。ネットワーク上の、バスコントローラでない装置はどれでもネットワーク・デバイスである。ネットワーク・デバイスは、この開示を通じて、しばしば遠隔デバイスと称される。ネットワーク・デバイス・インターフェイス(Network Device Interface;NDI)は、ネットワーク・デバイスの構成要素である。NDIは、バスコントローラおよびバス上の他のトラフィックを聞き、ネットワークバス上のトラフィックに応じて、動作を行なうか、またはネットワーク・デバイスに動作を行なわせる。大抵のNDIは、少なくとも1つまたは複数のデータチャネルに接続される。データチャネルは、センサ、アクチュエータ、センサおよび信号調整、アクチュエータおよび信号調整、またはその他アナログまたはデジタルシステムである。データチャネルは、ネットワーク・デバイスの構成要素であるか、またはネットワーク・デバイスに接続される。
【0012】
後に詳しく記載するように、この発明は、センサ、アクチュエータおよびサブシステムなどのさまざまなデータチャネルを共通のコントローラに接続して、データチャネルおよびコントローラからの、ならびにデータチャネルおよびコントローラへの、コマンドならびにデータの伝送を行なうためのネットワーク・デバイス・インターフェイス(NDI)を提供することによって、これらの問題およびその他の問題を解決する。重要なことは、この発明のNDIデバイスは、共通のネットワークを介してさまざまなデータチャネルをコントローラに接続することであり、このことによって、さまざまなデータチャネルが同じ配線を共有してコントローラと通信可能となることである。さらに、この発明のNDIは、アナログ−デジタル、またはデジタル−アナログ、もしくはその他であり得る、異なる種類のデータチャネルをインターフェイスすることができる。センサはアナログ−デジタルのデータチャネルとしてNDIに接続され、アクチュエータはデジタル−アナログのデータチャネルとしてNDIに接続される。この発明のNDIは、アナログ−デジタルのチャネルからデジタルデータをとり、適切なプロトコルに従ってそれをフォーマットし、適切なプロトコルに従ってそれをネットワーク上で伝送することができる。この発明のNDIは、ネットワークからデジタルデータをとり、それをデジタルデータとしてデジタル−アナログのコンバータ(D/A)に与え、D/Aにそのデータをアナログ信号に変換させることもできる。NDIがそのデータチャネルから直接アナログ信号を受取り、またはそのデータチャネルに直接アナログ信号を生成する、NDIの他の実施例も可能である。デジタルフォーマットでネットワーク上でデータを伝送することにより、コマンドおよびデータは、雑音および劣化の影響を受けにくい。
【0013】
さらに、この発明のNDIデバイスは、ネットワーク上で一度に1つまたはいくつかのネットワーク・デバイスとコントローラが通信することを可能にするデータプロトコルとともに作動する。重要なのは、この発明のNDIデバイスによって使用されるデータプロトコルは、固定された低レベル命令セットを有することである。プロトコルが単純なため、この発明のNDIデバイスは、高レベルプロセッサである必要はない。その代わりに、好ましい一実施例では、この発明のNDIのデバイスは、特定用途向け集積回路(ASIC)として実現されるステートマシンである。マイクロコントローラまたはプロセッサの代わりにステートマシンを使用してNDIデバイスを実現することの利点は、多くのプロセスを同時に行なえることであり、このことは、NDIデバイスが時間決定的かつ高速となるのを支援する。
【0014】
有利には、一実施例において、この発明は、同期通信または非同期通信のいずれかを使用して、コントローラとデータチャネル間でコマンドおよびデータを通信可能なネットワーク・デバイス・インターフェイスを提供する。この実施例では、NDIデバイスは、共通のデジタルバスを介してコントローラからメッセージを受取るための受信機を有する。この実施例のNDIデバイスは、受信機によって受取られたメッセージに応答して、関連づけられるデータチャネルにコマンドを与えかつ関連づけられるデータチャネルからデータを受取るための、インターフェイスをさらに含む。さらに、NDIデバイスは、共通のデジタルバスを介してコントローラにメッセージを伝送するための送信機も含む。重要なのは、NDIデバイスが同期ネットワークバスクロック検出器をさらに含むことである。
【0015】
作動中、コントローラからデータが受取られると、この発明のNDIデバイスのクロック検出器は、クロック信号がコントローラからのデータに付随するかを判断する。もしクロック信号が存在すれば、コントローラは同期モードで通信している。この場合、NDIデバイスは、クロック信号を使用して、データチャネルにコマンドおよびデータを与え、データチャネルからデータを受取る。さらに、この発明のNDIデバイスの送信機は、バスクロック信号を使用してデータをコントローラに伝送する。
【0016】
しかしながら、NDIデバイスのクロック検出器がコントローラからのデータに関連づけられるクロック信号を検出しない場合、NDIデバイスは、バスコントローラが非同期モードで作動していると判断する。この場合、NDIデバイスは、バスクロックから独立して、非同期モードでデータをデータチャネルに与え、データチャネルからデータを受取る。さらに、この発明のNDIデバイスの送信機は、同期モードのバスクロックから独立して、非同期でコントローラにデータを伝送する。
【0017】
一実施例において、コントローラは、共通のクロックバスを介して同期信号を与える。この場合、この発明のクロック検出器は、同期クロック信号を受取り、信号を分析して、それがデータビットと同じレートで送信されているかを判断する。もしそうであれば、ネットワーク・デバイス・インターフェイスのクロック検出器は、コントローラが同期モードで作動していると判断する。
【0018】
さらに、いくつかの実施例では、この発明のネットワーク・デバイス・インターフェイスは、共通のデジタルバスに接続されるビットレート検出器をさらに含んでもよい。この実施例では、コントローラが非同期モードで作動している場合、コントローラは或るビットレートでコマンドおよびデータを伝送している。この発明のビットレート検出器はビットレートを検出し、NDIデバイスはこのビットレートを使用してデータチャネルにコマンドおよびデータを送信し、データチャネルからデータを受取る。さらにこの発明の送信機は、検出されたビットレートを使用してコントローラにデータを送り返す。
【0019】
規定されたビットレートで非同期モードを使用してデータを伝送することに加え、コントローラは、通信中にビットレートを変更することもできる。この実施例では、まず、コントローラは、或る予め定められたビットレートで第1のメッセージをデータチャネルに送ることができる。この実施例では、クロック検出器は同期クロック信号を検出しないが、ビットレート検出器は、メッセージがコントローラによって伝送される第1のビットレートを検出する。この第1のビットレートに基づいて、この発明のネットワーク・デバイス・インターフェイスは、このビットレートを使用して、コマンドおよびデータをデータチャネルに送り、データチャネルからデータを受取る。さらに、この発明の送信機は、検出された第1のビットレートを使用してデータをコントローラに送り返す。
【0020】
第1のメッセージまたはいくつかのメッセージが第1のビットレートで送られた後、コントローラは、ビットレートを変更して第2のメッセージを第2のビットレートで送ることができる。この実施例では、NDIデバイスのビットレート検出器は、メッセージがコントローラによって伝送される第2のビットレートを検出する。この第2のビットレートに基づいて、この発明のNDIデバイスは、このビットレートを使用して、バスコントローラからコマンドおよび引数を受取り、バスコントローラにデータを送り返す。
【0021】
一実施例では、コントローラは、コマンドおよびデータを送るために以前に使用されたビットレートから変更されたビットレートで、例としてのメッセージを送ってもよい。この実施例では、NDIデバイスのビットレート検出器は、ビットレートの変化を検出し、NDIデバイスの送信機は、新しいビットレートでコントローラにデータを送り返し、ビットレートが変更されたことを示す。さらに、別の実施例では、コントローラは、メッセージが伝送されるべきビットレートを規定するボー選択コマンドを送ることもできる。
【0022】
上述のように、この発明のNDIデバイスはプロトコルとともに作動する。一実施例では、プロトコルは、複数の異なるアドレスを使用して、同時に1つまたはいくつかのデータチャネルをアドレス指定する。たとえば、この発明の一実施例では、プロトコルは、論理アドレスを使用して個々のデータチャネルをアドレス指定し、グループアドレスを使用していくつかのデータチャネルをアドレス指定し、グローバルアドレスを使用して同時にすべてのデータチャネルをアドレス指定する。この実施例では、論理マスクおよびグループマスクは、この発明のNDIデバイスに関連づけられる記憶装置に記憶される。グループマスクは、NDIデバイスが各チャネルのためのグループアドレスのリストを記憶するのに効率のよい方法である。グループマスクは、各データチャネルについての複数のビットを含むものと解釈される。マスクの各ビットは、それぞれのグループに関連づけられ、それぞれのデータチャネルがグループのメンバーであることを示す第1の状態、およびそれぞれのデータチャネルがグループのメンバーでないことを示す第2の状態を有する。マスクは、ネットワーク・デバイス・インターフェイスに関連づけられるメモリにも記憶される。
【0023】
この実施例では、コマンドまたはデータがいつ送られようと、それは論理アドレス、グループアドレスまたはグローバルアドレスのどれかを含む。送られる各コマンドまたはデータメッセージについて、そのメッセージに関連づけられるアドレスがNDIデバイスによって分析される。アドレスがグローバルであれば、NDIデバイスはそのコマンドを実施する。同様に、アドレスが論理アドレスであり、NDIデバイスに関連づけられるデータチャネルの論理アドレスに対応する場合、NDIデバイスはコマンドを実施する。アドレスがグループアドレスである場合、この発明のNDIデバイスは、それぞれのデータチャネルに関連づけられるマスクを分析することによって、NDIデバイスに関連づけられるデータチャネルがそのグループアドレスによって規定されるグループのメンバーであるかを判断する。ネットワーク・デバイス・インターフェイスは、データチャネルがそのグループアドレスを有するグループのメンバーである場合のみ、コマンドを実施する。
【0024】
上述のように、この発明のNDIデバイスは、同期モードまたは非同期モードのどちらでも作動可能である。さらに、コントローラは、グループアドレスを与えて複数のデータチャネルに同時にコマンドを送ることができる。しかしながら、各データチャネルに接続されるNDIデバイスが非同期モードで作動している場合、NDIデバイスを同期させて、グループアドレスに関連づけられるコマンドを、NDIデバイスに接続されるそれぞれのデータチャネルにNDIデバイスが同時に適用するようにすることが困難だという点において、問題が発生する。このことを考慮して、一実施例では、NDIデバイスは、それらが非同期モードで作動している場合でも同期させることができる。
【0025】
特に、この発明の一実施例では、コントローラはコマンドを複数のデータチャネルに伝送し、この場合、コマンドは、第1の状態と第2の状態との間の遷移によって規定される値を有する複数のビットを含む。この実施例では、この発明のNDIデバイスの各々は、複数のネットワーク・デバイス・インターフェイスが時間で決定される形でコマンドを同時に実行するように、コマンドのそれぞれのビットの値を規定する遷移に比例して予め定められた同じ時にコマンドの実施を開始する。さらに一実施例では、コントローラは、同期部、メッセージ本体およびパリティビットを含むコマンドを伝送する。この実施例では、この発明のNDIデバイスは、パリティビットの値を規定する遷移と同時にコマンドの実行を開始する。さらに別の実施例では、コントローラは、スタートビットと、コマンド領域と、0にセットされた未使用の最後のビットを有するアドレス領域と、1にセットされたストップビットとを含むコマンドを伝送する。この実施例では、この発明のNDIデバイスは、アドレス領域の未使用ビットからストップビットへの遷移と同時に、各データチャネルでの機能の実現を開始する。
【0026】
さらに上述のように、同期モードでは、コントローラは同期クロック信号を共通のデジタルバス上で伝送する。この実施例では、この発明のNDIデバイスは、同期クロック信号を使用することによって、いくつかのネットワーク・デバイス・インターフェイス間で同期してコマンドを実行することも可能にし得る。具体的には、この実施例では、コントローラは、複数のデータチャネルにコマンドを伝送し、メッセージは、第1の状態と第2の状態との間の遷移によって規定される値を有する複数のビットを含む。さらに、コントローラは、メッセージと同時に、複数のクロックパルスを含む同期クロック信号をコントローラから複数のデータチャネルへ伝送する。この実施例では、複数のネットワーク・デバイス・インターフェイスは、それぞれのクロックパルスによって規定される予め定められた同じときにコマンドの実行を開始し、それぞれのクロックパルスは、メッセージのそれぞれのビットに対する予め定められた関係に基づいて規定される。
【0027】
たとえば、一実施例において、ネットワーク・デバイス・インターフェイスは、メッセージのそれぞれのビットに続く第1のクロックパルスに同期して、実行を開始する。具体的には、一実施例では、伝送されるメッセージは、第1の状態と第2の状態との間の遷移によって規定される値を有する複数のビットを有し、メッセージは、同期部、メッセージ本体およびパリティビットを規定する。この実施例では、ネットワーク・デバイス・インターフェイスは、それぞれのクロックパルスによって規定される予め定められた同じときにコマンドの実行を開始し、それぞれのクロックパルスは、メッセージのパリティビットの値を規定する遷移に対する予め定められた関係に基づいて規定される。
【0028】
上述のように、この発明のNDIデバイスは、簡略化したコントローラおよびネットワーク・デバイス・インターフェイスをネットワーク・デバイス上で使用することを場合によっては可能にする固定された低レベル命令セットを有するプロトコルとともに作動する。具体的には、一実施例では、この発明は、コンピュータ読取可能な記録媒体に記憶されるプロトコルを提供する。プロトコルは、共通のデジタルネットワークを通じてコントローラおよびネットワーク・デバイス・インターフェイス間でコマンドおよびデータを伝送するために使用される。重要なのは、プロトコルは、それぞれのコマンドおよび引数をデータチャネルに送るために、コマンドおよびデータ構造のうちの少なくとも1つを含むことである。データ構造も、データチャネルからバスコントローラにデータを送るために使用される。
【0029】
このことを考慮して、この発明は、ステートマシンを使用するシリアルな多重化された通信システムも提供する。特に、この発明の通信システムは、複数のコマンドを発行するためのコントローラ、およびコマンドに応答して予め規定された機能を実現するための複数のデータチャネルを含む。コントローラとネットワーク・デバイス・インターフェイスとを接続しているのは、それらの間の通信を支援するための共通のデジタルバスである。さらに、通信システムは、複数のネットワーク・デバイス・インターフェイスを含み、それらの1つは、各データチャネルに関連づけられて、それぞれのデータチャネルを共通のデジタルバスに相互接続する。この実施例では、各ネットワーク・デバイス・インターフェイスは、ステートマシンを含み、プロセッサから独立している。
【0030】
先に述べたように、同期モードでは、コントローラは、ネットワークバス上でネットワーク・デバイス・インターフェイスに同期クロック信号を与える。同期モードでは、同期クロックは、データを伝送するためのクロック信号として使用される。しかしながら、A/DコンバータおよびD/Aコンバータならびに信号調整デバイスの中には、同期クロックによってセットされるクロック速度で作動することができないものがある。このことを考慮して、この発明の一実施例では、ネットワーク・デバイス・インターフェイスはクロック分割器を含んでもよい。クロック分割器は、コントローラによって同期クロック信号を出力に接続されてもよいし、またはローカルの発振器に接続されてもよい。
【0031】
具体的には、この実施例では、バスコントローラがあり、1つの周波数で同期クロック信号およびコマンドをネットワーク・デバイスに送り、NDIデバイスは、バスコントローラからの同期クロックおよびデータを聞く。NDIデバイスは、バスコントローラからのデータおよびコマンドを、NDIデバイスに接続されるデータチャネルによって期待される適切なフォーマットに変換し、同時にNDIデバイスは、分割された第2のクロック信号をデータチャネルに与えて、コントローラおよびNDIデバイスが第1のクロック周波数と一致して作動して、コマンドおよびデータをネットワークバス上で送る一方で、データチャネルが第2のクロック信号周波数と一致して作動しデータを変換するようにする。
【0032】
さらに別の実施例では、この発明のNDIデバイスは、各NDIデバイスに関連づけられる分割器を共通のデジタルバスに接続される他のすべてのNDIデバイスの分割器と同期させるための方法もさらに含む。特に、上述のように、いくつかの実施例では、コントローラは、コマンドが複数のデータチャネル上で同時に実行されるように、グループアドレスを送る。しかしながら、これを行なうには、各NDIデバイスに配置される分割されたクロックを使用するデータチャネルに設けられるクロック分割器のすべてを同期させなければならない。このことを考慮して、一実施例では、コントローラは共通のバスにわたって第1のクロック信号を送る。さらに、コントローラは、分割器の各々にそれらのそれぞれの第2のクロック信号の伝送を第1のクロック信号のエッジと同期させるように命令して、分割器の各々によって与えられる個々の第2のクロック信号が第1のクロック信号に対して同期し、このことによってコンバータの各々が同期するようにする。
【0033】
異なるクロック信号に従って作動することに加え、A/DおよびD/Aコンバータの中には、コントローラによって使用されるコマンドとは異なる特別なコマンドに従った作動も行なうものがある。このことを考慮して、この発明のネットワーク・デバイス・インターフェイスは、コンバータのための特別なコマンドを与えるために使用される特別な特徴を含み得る。この特徴はコマンド変換と呼ばれる。このため、作動中、この発明のNDIデバイスは、第1のセットのコマンドに従ってコントローラからコマンドおよびデータを受取り、第2のセットのコマンドに従ってそのコマンドを変換してコンバータに適用する。さらに、この発明のNDIデバイスは、第1のセットのコマンドに従って、コンバータから受取ったデータを共通のデジタルバスを通じて送ることもできる。
【0034】
NDIデバイスに好ましいプロトコルは、NDIデバイスの小型化を可能にするように、ネットワークデータビットのマンチェスター符号化を使用する。どのようなデバイスでも非同期シリアルデータを受取るには、シリアルデータストリームからデータシーケンスのタイミングを取得できなければならないことを理解されたい。通常、シリアル非同期データの受信機は、その受信機を作動させ、シリアルデータからタイミング情報を回収するためにローカルの発振器を有しなければならない。一旦タイミング情報が抽出されると、ローカルの発振器の周波数があれば、非同期受信機は、或るレートでシリアルデータを受取ることができ、これらのレートから或る偏差分増加または減少したレートで受信することができる。シリアルデータのマンチェスター符号化によって、各ビットの中央でhighからlowへ、またはlowからhighへの遷移が起こる。このことによって、シリアルデータストリームから必要なタイミング情報を抽出することが容易になる。マンチェスター符号化されたシリアルデータストリームからタイミング情報を抽出することは容易であるため、予想されるデータレートからの比較的大きな偏差も、ローカルの発振器に基づいて許容され得る。予想されるデータレートからの比較的大きな偏差に対してこのように許容差があるため、各NDI受信機は、精度の低いローカルの発振器を使用してマンチェスター符号化されたデータを受取ることができる。精度の低いローカル発振器は、極めて小型化することができる。適切なローカル発振器の現在の実施例は、わずか約1×1.5ミリメートルである。このことはNDIデバイスの小型化に役立つ。
【0035】
[詳細な説明]
ここからは、この発明の好ましい実施例が示される添付の図面を参照して、この発明をさらに十分に説明する。しかしながら、この発明は、多くの異なる形で実現可能であり、ここに示される実施例に限定されるものと解釈すべきではない。そうではなく、これらの実施例はこの開示を完璧かつ完全なものとし、当業者にこの発明の範囲を十分に伝えるために与えられるものである。同じ参照番号は、全体を通じて同じ要素を示す。
【0036】
上述のように、多くの従来のデータ取得および制御システムは、個々の配線を使用して、センサ、アクチュエータおよびサブシステムなどの遠隔デバイスを中央コントローラに接続し、データ取得および制御を行なっている。遠隔デバイスの数が多いため、これらのデバイスの各々のための個々の配線を合計すると、高価でかさばり、重く、しかも設置および維持が難しいものとなり得る。さらに、これら遠隔デバイスの多くは、アナログであるため、遠隔デバイスからの信号および遠隔デバイスへの信号は、雑音および信号の劣化の影響を受けやすい。
【0037】
後にさらに詳細に記載するように、この発明は、センサ、アクチュエータおよびサブシステムであり得るさまざまなデータチャネルを共通のコントローラに接続して、データチャネルおよびコントローラでコマンドならびにデータを伝送し合うためのネットワーク・デバイス・インターフェイス(NDI)を提供することによって、これらの問題および他の問題を解決する。重要なのは、この発明のNDIデバイスが共通のネットワークを介してさまざまな遠隔デバイスをコントローラに接続することであり、このことによって、さまざまな遠隔デバイスは同じ配線を共有してコントローラと通信することができる。さらに、この発明のNDIは、アナログからデジタル、またはデジタルからアナログまたはその他であり得る、異なる種類のデータチャネルにインターフェイスすることができる。センサは、アナログ−デジタル・データチャネルとしてNDIに接続され、アクチュエータは、デジタル−アナログ・データチャネルとしてNDIに接続される。この発明のNDIは、アナログ−デジタル・チャネルからデジタルデータをとり、適切なプロトコルに従ってそれをフォーマットし、プロトコルに従ってそれをネットワークに伝送することができる。この発明のNDIは、ネットワークからデジタルデータをとり、それをデジタルデータとしてデジタル−アナログ・コンバータ(D/A)に与え、D/Aにそのデータをアナログ信号に変換させることもできる。NDIの他の実施例は、そのデータチャネルにアナログ信号を直接生成し、またはそのデータチャネルからアナログ信号を直接受取ることも可能である。デジタルフォーマットでネットワークでデータを伝送することにより、コマンドおよびデータは、雑音および劣化の影響を受けくい。
【0038】
さらにこの発明のNDIは、コントローラがネットワーク上で1つまたはいくつかのネットワーク・デバイスと同時に通信することを可能にするデータプロトコルとともに作動する。重要なのは、この発明のNDIデバイスによって使用されるデータプロトコルは、固定された低レベル命令セットを有することである。プロトコルが単純であるため、この発明のNDIデバイスは高レベルプロセッサである必要はない。その代わりに、好ましい一実施例では、この発明のNDIデバイスは、特定用途向け集積回路(ASIC)として実現されるステートマシンである。マイクロコントローラまたはプロセッサの代わりにステートマシンを使用してNDIを実現する利点は、多くのプロセスを同時に行なえることであり、このことによって、NDIが時間決定性を持ち、かつ高速となるのが支援される。
【0039】
上述のように、この発明のNDIは、共通のコントローラと、共通のネットワークによってそのコントローラに接続されるさまざまなネットワーク・デバイスとの間のインターフェイスとして使用される。図1は、この発明のインターフェイスの実現の一実施例を示す。この図示は、この発明がより完全に理解されるようにするために与えられる。この発明は、この構成に限定されるのではなく、多くの異なるネットワークシステムで実現可能であることを理解されたい。NDIのこの実施例は、RHAMIS−HSプロトコルを使用するが、この開示によって企図される他の実施例は、他のプロトコルを使用し得る。
【0040】
図1を参照すると、この発明が使用されるネットワークシステム30の一般的な実施例が示される。具体的には、このネットワークシステムは、高レベルプロセッサまたはパーソナルコンピュータなどのマスターコントローラ32を含み、これが、ネットワーク内の所望の点に位置するセンサ、アクチュエータおよびサブシステムなどのデータチャネル34からのデータを処理し、コマンドおよびデータをデータチャネル34に送る。重要なのは、ネットワークシステムがマスタコントローラ32とネットワークバス38との間に接続されるネットワークコントローラ36、およびネットワークバスとデータチャネルとの間に接続される1つまたはいくつかのNDIデバイス40をさらに含むことである。ネットワークコントローラおよびNDIデバイスをネットワークバスに接続するのは、それぞれの送信器42〜46および受信器48〜52である。ネットワークコントローラとネットワークバスとの間に接続される第1の送信器42は、ネットワーク上でコマンドおよびデータを伝送し、これもネットワークコントローラとネットワークバスとの間に接続される第2の送信器44は、同期クロック信号を伝送するために使用することができる。
【0041】
通常動作において、センサである遠隔デバイスは、検討中の特定のオブジェクトに接続され、温度、歪み、屈曲、速度、空気の流れ等のそのオブジェクトの特性を検知する。さらに、アクチュエータである遠隔デバイスは、機械的な部材およびその他の構造体に接続されて、テスト中のオブジェクト上で作動する。1つまたはいくつかの遠隔デバイスは、コンバータおよび信号調整デバイスを含む個々のデータチャネルを介して、この発明の1つのNDIデバイスに接続される。さらに、データおよびコマンドをネットワーク上でさまざまなネットワーク・デバイスに送信するように、マスターコントローラまたはネットワークコントローラのどちらかを構成することができる。これらコントローラの両方がそのような動作が可能であるため、バスコントローラという総称は、以下の議論において、マスターコントローラまたはネットワークコントローラのどちらかによって行なわれ得る動作を示すのに使用される。
【0042】
図2を参照すると、センサからデータを取得するため、またはアクチュエータを作動させるため、コントローラは、ネットワークを通じて、コマンドおよびデータを遠隔デバイスにデジタル方式で送り、コマンドおよびデータは、遠隔デバイス上のデータチャネルの1つまたはグループのために設計されている(ステップ200を参照)。コマンドおよびデータは、データプロトコルを使用して、ネットワーク上で伝送される。この発明のNDIデバイスは、データプロトコルの構造を使用して、データおよびコマンドを受取り、解釈する(ステップ210を参照)。さらに、この発明のNDIデバイスは、コマンドおよびデータがそこに接続されるデータチャネルのために指定されているかを判断する(ステップ220を参照)。もしそうであれば、NDIは、それがセンサであれば、指定されたデータチャネルからデータを取得し、またはそれがアクチュエータであれば、データチャネルに変換を行なうように命令する(ステップ230を参照)。センサチャネルから検索されるアナログデータは、まずデジタルデータに変換され(ステップ240を参照)、次に、データプロトコルに従って適切なフォーマットに変換される。さらにデジタルデータは、コントローラに伝送される(ステップ250を参照)。
【0043】
図1および2に示されるように、この発明のNDIデバイスは、バスコントローラとデータチャネルとの間のインターフェイスとして作動する。重要なのは、この発明のNDIデバイスは、データチャネルからデジタル化されたアナログデータ信号を受入れ、ネットワークバス上で伝送できることである。NDIは、バスコントローラからデジタルデータを受入れ、それをデータチャネルに与えることもできる。次にD/Aコンバータは、データをアナログ信号に変換することができる。データチャネルの中には、デジタルデータをアナログに変換することなく、直接それを受入れ使用することも可能であるものもある。NDIのいくつかの実施例は、NDIに一体化されたアナログ−デジタル(A/D)コンバータおよびD/Aコンバータを有してもよく、このことによって、アナログ信号をデータチャネルから受入れ、またはデータチャネルへ与えるように構成される。この発明のNDIデバイスは、選択されたデータプロトコルとともに作動して、ネットワークバスを介して適切にデータを受取りかつデコードし、またはフォーマットし、データを効率よく送信することができる。
【0044】
さらにこの発明のNDIデバイスは、データチャネルを構成する異なる種類のデバイスとコントローラが通信することを可能にする、たとえば、プログラム可能なトリガコマンド変換およびクロック信号などの、付加的な動作および特徴も提供する。これに加えて、この発明のNDIデバイスは、そこに接続されるデータチャネルを構成するための記憶された情報および手順を含む。A/DおよびD/Aコンバータは、プログラムする必要のあり得るまたは構成する必要のあり得るデータチャネルの構成要素の例である。この発明のNDIデバイスは、ローカルの発振器または同期バスクロックの何らかの断片または複数のローカル発振器または同期バスクロックであるローカルクロック信号をデータチャネルに与えることもあり得る。ネットワーク上の多くのまたはすべてのNDIデバイスのローカルクロック信号は、バスコントローラによって同期させることができる。さらにこの発明のNDIデバイスは、データチャネルを、個々に、同期グループで、またはすべてまとめてアドレス指定することができるように、データプロトコルとともに作動して、一意の論理アドレスおよびグループアドレスをデータチャネルの各々に与える。
【0045】
コントローラおよび遠隔デバイスならびに異なる構成を有するデータチャネルの間でのデータ通信を可能にすることに加え、この発明のNDIデバイスは、異なるデータ伝送モードを使用する、バスネットワーク上でのデータ通信も可能にする。具体的には、この発明の1つのモードでは、この発明のNDIデバイスは、同期モードでコントローラとともに作動し、コントローラによって与えられる同期クロック信号は、バスコントローラからコマンドおよびデータを受取るためにNDIデバイスによって使用される。この同じ同期クロック信号をNDIが使用して、データをバスコントローラまたはその他のネットワーク・デバイスに送信する。
【0046】
注意すべきことは、通常、NDIデバイスは、同期バスクロック信号をバスコントローラに送り返さないことである。その代わり、通常、NDIデバイスは、同期モードでは同期バスクロック信号を受信したエッジでデータの出力時刻を記録する。一般に、バスコントローラのみが同期バスクロック信号を伝送する。さらに、通常、バスコントローラは、NDIデバイスからデータを受取るために非同期受信器を含む。
【0047】
同じ実施例または異なる実施例となり得る別のモードでは、NDIデバイスは、非同期モードでコントローラとともに作動する。この実施例では、この発明のNDIデバイスは、コントローラがネットワークバス上でデータを伝送しているレートを分析および判断して、このビットレートを使用してバスコントローラからコマンドおよびデータを検索し、バスコントローラまたはその他のネットワーク・デバイスにデータを送る。非同期モードでも、NDIデバイスは、異なるNDIデバイス上にあるデータチャネルでのデータ変換を同期させることができる。データ変換は、バスコントローラからのコマンド内の特別なビットのエッジの変化で、またはその直後にそれを行なうことによって、異なるデータチャネル上で同期される。
【0048】
これらの利点および他の利点は、この発明のNDIデバイスによって実現され、その一実施例は、図3Aおよび図3Bに示される。特に、図3Aは、この発明の一実施例による、NDIデバイス40の一般的なブロック図である。図示のように、この発明のNDIデバイスは、先に図1に示したように、ネットワークバス38と遠隔デバイス34および36との間に接続される。この実施例では、遠隔デバイス34の1つはセンサであり、もう一方の遠隔デバイス36は、アクチュエータまたは同様の装置である。両方の遠隔デバイスとも、アナログ信号を調整するための信号調整デバイス58および60を含む。遠隔デバイス34に関しては、信号調整58はセンサ信号用である。アクチュエータのための信号調整は、60に示される。信号調整は、増幅器、フィルタ、減衰器等を含み得るが、これらに限定されない。
【0049】
重要なのは、遠隔デバイスと、この発明のNDIデバイスとの間に接続されるのは、それぞれA/Dコンバータ62およびD/Aコンバータ64であるということである。A/Dコンバータ62は、NDIデバイスとセンサ34との間に接続される。A/Dコンバータは、センサチャネルからのアナログ信号をデジタルデータに変換して、NDIデバイスに入力する。同様に、D/Aコンバータ64は、NDIデバイスとアクチュエータ装置36との間に接続され、NDIデバイスからのデジタル信号をアナログ信号に変換して、アクチュエータチャネルに入力する。センサおよびアクチュエータの中には、デジタル信号を直接生成または受信し得るものがあるため、A/D62またはD/A64が必要でない場合もあり得る。
【0050】
先に図1に示したように、この発明のNDIデバイスは、コントローラからコマンドおよびデータを受取る第1の受信器50を介して、ネットワークバスに接続される。第2の受信器52も、ネットワークが同期モードで作動している場合にコントローラから任意の同期クロック信号を受取るために設けられる。送信器46も、データをコントローラに伝送するために、この発明のNDIデバイスとネットワークバスとの間に接続される。さらに、記憶装置66およびローカルの発振器68は、この発明のNDIデバイスに接続される。NDIデバイスの異なる実施例は、受信器、送信器、ローカルの発振器およびメモリの一部またはすべてを組込み得る。
【0051】
図3Bは、この発明の一実施例によるNDIデバイス40のさまざまな制御論理構成要素を示す。特に、この発明のこの実施例のNDIデバイスは、データチャネル34および36に接続するためのポート70および72を含む。通常、これらポートはシリアルポートであるが、いくつかの実施例では、パラレルポートであってもよい。NDIデバイスのポートは、個々のポートコントローラ74および76によって制御される。各ポートに組込まれるデータ線は、シリアルMOSI(master out slave in;マスター・アウト・スレーブ・イン)と称されるデータ出力線78、CEと称されるチップ可能化またはチップ選択線80、シリアルCLKと称されるクロック信号線82およびトリガ84を含む。図示のように、データ出力線78は、構成データ出力線78aおよびデータ出力/特別コマンド出力線78bからなる。構成データ出力線78aは、後に説明するように、パワーアップ時にデータチャネルを構成するために使用される。さらに、データ出力/特別コマンド出力線は、バスコントローラからのデータをデータチャネルに与える。出力選択線79は、NDIデバイスがパワーアップモードであるか、または通常動作であるかに応じて、構成データ出力線とシリアル出力データ線との間で選択スイッチ86のトグル動作を行なう。
【0052】
上述のように、この発明のNDIデバイスは、メモリを作る複数のデータレジスタとして規定されるデータスタック88をさらに含む。データスタックは、データチャネルから取得されたデジタルデータを記憶するために使用される。データスタックは、データチャネルに送信するためのバスコントローラからのデータを記憶するためにも使用することができる。通常、データスタックは、後入れ先出し(last in first out;LIFO)デバイスとして作動し、ここでは、データスタックに最後に位置づけられたデータが最初にデータスタックから検索される値である。このようにして、スタックのサイズにかかわらず、データは、異なるNDIデバイスによって同じ順序でバスコントローラに戻される。新しいデータの値をスタックの最上部に置いてから、バスコントローラがそれを読取ることが可能になるまでの遅延は、最低限になる。しかしながら、バスコントローラがスタックの底部からデータを読取らなければならないのであれば、大きな遅延が生じるであろう。
【0053】
図示のように、データスタックに関連づけられるのは、スタック深さレジスタ90である。スタック深さレジスタは、その時点でのスタック内の有効なデータワード数を示す。
【0054】
さらに、この発明のNDIデバイスの現在の実施例の内部には、各データチャネルのための状態レジスタ92およびデータ選択マルチプレクサ94がある。重要なのは、状態レジスタが、たとえば、データチャネルがレディモードであるか、データチャネルがコマンドをサポートするか、またはメッセージ伝送エラーがあるか等の、データチャネルの状態に関する情報を含むことである。データ選択マルチプレクサは、要求されるデータに応じて、状態レジスタ、データスタックまたはスタック深さレジスタのいずれかを出力データマルチプレクサ96に接続する。各チャネルについてのデータ選択マルチプレクサ94は、それぞれのポートコントローラ74および76によって制御される。出力データマルチプレクサ96は、2つの遠隔デバイスの出力またはデバイス・インベントリ・レジスタ98の出力から選択する。NDIデバイスの異なる実施例は、NDIデバイス内に異なるマルチプレクサの配置を有し得るが、その効果は常に、バスコントローラが、必要とするNDIデバイス内のどのデータチャネルのためのレジスタにもアクセスできるようにすることである。
【0055】
デバイス・インベントリ(Device Inventory)・ブロック98は、図8のフローチャートに示されるデバイス・インベントリ・オペレーションを実行するためにNDIデバイスによって使用される。
【0056】
さらにこの発明のNDIデバイスは、アドレスデコーダ100およびコマンドデコーダ102も含む。後に説明するように、これらデコーダは、コントローラによって伝送されるコマンドおよびデータを受取り、コマンドおよびデータをデコードし、そのコマンドおよびデータがNDIデバイスに接続されるデータチャネルの1つまたは複数にアドレス指定されているかを判断する。コマンドおよびデータがデータチャネルの1つについてアドレス指定されている場合、この発明のNDIデバイスは、コマンドに従ってそのデータチャネル上で作動する。上述の構成要素は、しばしばここでは、デバイス・インターフェイスと称される。
【0057】
NDIデバイスは、UUID、プロトコルバージョン、データチャネルの数、論理アドレス、グループマスク、構成データ、および製造者またはユーザが規定し得るその他のデータを記憶するためにNDIが使用する記憶装置66として、図3Aに示される不揮発性メモリを含む。この記憶装置との通信は、構成レジスタ104から記憶装置への入出力線によって、図3Bに示される。バスコントローラは、プロトコルに従ってメモリを読出し、さまざまな記憶場所に書込むことができる。メモリ内の論理アドレスおよびグループマスク領域は特別である。これらは、図8のフロー図に従ってNDIデバイスがデバイス・インベントリ競合(Device Inventory Competition)に勝った直後に、バスコントローラによってのみ書込むことができる。このことによって、すべてのNDIデバイスがバスコントローラによって一意に識別されることが可能となり、論理アドレスおよびグループマスクを割当てることが可能となる。これらの領域に書込む前にデバイス・インベントリ競合に勝たなければならないと命令することによって、これらの値を偶然変更することは事実上不可能となる。これと同じ種類のメモリ保護は、NDIデバイス製造者によって他のメモリ領域に適用することが可能である。
【0058】
パワーアップ時、不揮発性メモリ66の内容の一部は、論理およびグループアドレスデコーダレジスタ100、シリアルポート70および72のための構成レジスタ104、ポートコントローラ74および76内のコマンド変換レジスタにロードされ、一部の内容は、データチャネルを構成するためにシリアルポートまたはその他のパラレルポートから送り出される。パワーアップ時、このメモリデータは、他にも使用され得る。このメモリは、ネットワーク・デバイス設置場所、較正データ等、ユーザが規定する情報を記憶するためにバスコントローラによって使用することもできる。通常、このメモリの内容は、トランスデューサ電子データシート(Transducer Electronic Data Sheet)を示すTEDと呼ばれる。
【0059】
さらに、この発明のNDIデバイスは、コマンドを受取り、内蔵テスト、較正を行ない、かつNDIデバイスをスリープモードおよびウエイクモードの間で遷移させるために、制御論理106を含んでもよい。
【0060】
図1に示されるように、この発明のNDIデバイスは、ネットワークバスを通じてコントローラと通信する。以下に記載する、この発明のさまざまな動作の説明は、NDIデバイスに関するものである。マスターコントローラおよびネットワークコントローラの詳細な動作は、ここには記載しない。しかしながら、マスターコントローラおよびネットワークコントローラの動作の完全な詳細な開示は、2000年12月8日出願の「共通のバスを介して遠隔デバイスをデジタル方式で制御するためのネットワークコントローラ(NETWORK CONTROLLER FOR DIGITALLY CONTROLLING REMOTE DEVICES VIA A COMMON BUS)」と題される米国仮特許出願番号第60/254,137号に提供される。この特許出願の内容を、ここに引用により援用する。
【0061】
上述のように、この発明のNDIデバイスは、いくつかの利点をもたらす。この発明のNDIデバイスの1つの重要な局面は、パワーアップ時にA/DおよびD/AコンバータならびにNDIデバイスに接続される遠隔デバイスが自己構成されることである。図1に示すように、ネットワークバスに接続される遠隔デバイスは、非常に多数でかつ非常に遠くに離れていることがあり得るため、中央の場所からデバイスを構成することは難しくなり得る。このことを考慮して、この発明の一実施例では、NDIデバイスは、信号調整デバイス58および60の利得、オフセット、フィルタ等に関するデータ、ならびに記憶装置66(図3Aに示す)に記憶されるA/DおよびD/Aコンバータに関連する情報を含む。具体的には、一実施例では、この発明のNDIデバイスは、パワーアップ時に、記憶装置から16の16ビットデジタルワードがポートの各々70および72を介して出力されるのを可能にする。この発明のNDIデバイスのこの局面は、市販のA/DコンバータおよびD/Aコンバータの自動構成を可能にしている。
【0062】
記憶装置に記憶される構成データは、コントローラによってプログラム可能である。16の16ビットワードは、32の8ビットバイトに分割して、ポートによってA/DコンバータおよびD/Aコンバータならびに信号調整に出力されるようにプログラム可能である。さらに、この発明のNDIデバイスは、構成データがポート70および72で出力されるときのシリアルクロック82の位相およびシリアルクロック82の極性を変更するために、コントローラによってプログラム可能である。
【0063】
パワーアップ時にA/DコンバータおよびD/Aコンバータならびに信号調整デバイスを構成することに加え、この発明のNDIデバイスは、異なる種類のA/DコンバータおよびD/Aコンバータならびに信号調整デバイスと作動するように構成可能でもある。具体的には、逐次近似A/Dコンバータおよびシグマ/デルタオーバーサンプリングコンバータ等、多くの種類のコンバータがある。これらのコンバータは、クロックおよび動作遅延の面から見て、異なる動作をし得る。さらに、スイッチド・キャパシタ・フィルタおよびデジタル・アンチエイリアス・フィルタなどの信号調整デバイスの中には、クロックの面から見て異なる動作をするものがある。
【0064】
たとえば、図1に示されるように、同期モードでは、コントローラはネットワークバスを通じてネットワーク・デバイスに同期クロック信号を与える。同期モードでは、同期クロック信号は、ネットワークデータを伝送するためのクロック信号として使用される。アナログ・デバイシズ(Analog Devices)社のAD7714コンバータなどのA/Dコンバータの中には、正しく作動するために連続するクロック信号を必要とするものもある。通常、このクロックは、コントローラによって与えられる同期クロック信号よりも低い周波数である。このことを考慮して、この発明の一実施例では、この発明のNDIデバイスは、クロック分割器108を含んでもよい。クロック分割器は、図3Bに示されるようにコントローラによって出力される同期クロック信号に接続されていてもよいし、または図3Aに示されるようにローカルの発振器68に接続されていてもよい。
【0065】
NDIデバイスによって与えられるこのクロック信号は、図9に示されるバスコントローラによって同期させることができる。クロック信号は、バス上の、1つ、いくつかまたはすべてのNDIデバイスで、同時に同期させることができる。図9の例では、内部クロック周波数は、同期バスクロック周波数の1/4として示される。実際には、これは同期バスクロック周波数の何分の1であってもよい。
【0066】
図4は、バスコントローラからの1つの特定のコマンドに応答してNDIによって行なわれる動作のブロック図である。この図は、NDIデバイスが1度に2つ以上の作業を行なえることを示す。NDIデバイスの同時に複数の作業を行なえる能力によって、この発明のNDIデバイスは、同時に1つまたは複数のデータチャネルを取得または制御する一方で、同時にバスコントローラと通信することができる。
【0067】
図4を参照すると、作動中、この発明のNDIデバイスは、まずトリガおよび読出(Trigger and Read)コマンドなどのコマンドをコントローラから受取り(ステップ310を参照)、そのコマンドを解釈する。コマンドおよびアドレスがNDIデバイス上のデータチャネルのためのものであれば、NDIデバイスは、ステップ330および360に示される動作を並行して開始する。具体的には、NDIデバイスは、NDIに装着されるデータチャネルに変換信号を送る(ステップ330を参照)。このデータパルスの立上がりエッジは、トリガおよび読出コマンドの終わりにパリティビットの中央エッジで起こる。変換信号は、アナログデータをサンプルにラッチし、A/Dコンバータの回路を保持するために与えられるか、または変換信号は、D/Aに変換プロセスを開始させるために使用することもできる。この信号の立上がりエッジの正確なタイミングによって、ネットワーク・デバイスが同期モードで作動していない場合でも、多くのデータチャネルは、いつアナログデータをサンプリングすべきか、または変換するべきかを知ることができる。
【0068】
変換信号が生成された後、短い休止が起こる(ステップ340を参照)。この休止によって、データチャネルは、そのサンプルにラッチされるアナログ信号を変換して、デジタル値に変換するように保持するための時間を有することができる。NDIデバイスのこの実施例では、この休止はプログラム可能である。2つの選択肢がある。これは僅か数百ナノ秒であってもよく、または6マイクロ秒にプログラムすることも可能である。
【0069】
休止の後、シリアル転送が行なわれる(ステップ350を参照)。このシリアル転送中、プログラム可能なワードの出力時刻がMOSI線上で記録される。このプログラム可能なワードは、特別なA/Dコンバータにデータを出力させるために使用される。例としては、AD7714がある。このシリアル転送が続く中で、データはデータチャネルからNDIデバイスに戻される。MOSI線上でNDIデバイスに戻されるデジタルデータは、データレジスタ89に記憶される。
【0070】
動作ステップ330、340および350が行なわれるのと同時に、動作ステップ360、370および380も行なわれる。動作ステップ360において、入力データレジスタ89の内容は、データスタックの最上部にシフトされる。次に、データスタックの最上部の内容は、送信機レジスタにロードされる(ステップ370を参照)。最後に、送信機レジスタの内容は、NDIデバイスの送信器46によってバスコントローラに送り返される(ステップ380を参照)。
【0071】
これら動作のすべての間、NDIインターフェイスは、連続したクロック信号をデータチャネルに与えている。すべてのデータチャネルがこのクロックを使用するわけではないが、使用可能である。このクロックの周波数はプログラム可能である。このクロック信号は、スイッチド・キャパシタ・フィルタ、デジタルフィルタまたはシグマ/デルタコンバータ等のデバイスを作動させるために有用である。このクロック信号は、動作ステップ300から380が行なわれていないときでも作動し続ける。
【0072】
汎用非同期送受信器(Universal Asynchronous Receiver Transmitter;UART)プロトコルが使用されている場合、コントローラは、スタートビット、コマンド領域、0にセットされる未使用の最後のビットを有するアドレス領域、および1にセットされるストップビットを含む、コマンドを伝送する。この実施例では、この発明のNDIデバイスは、アドレス領域の未使用ビットからストップビットへの遷移と同時に、各データチャネルでの関数の実行を開始する。
【0073】
クロックおよび遅延の発行に加え、A/DコンバータおよびD/Aコンバータの中には特別なコマンドも必要とするものがある。たとえば、A/DコンバータおよびD/Aコンバータの中には、センサからの異なる読取値をとるようにプログラム可能なものもある。たとえば、1つの応用例では、A/Dコンバータは、3次元で歪みを感知する歪みゲージに接続される。各読取可能な寸法は、別々の16ビットのアドレスでアドレス指定可能である。各寸法の測定値の1つまたはすべては、関連づけられる16ビットコマンドをコンバータに適用することによってアクセス可能である。ビットコマンドのすべてをコントローラに記憶して、それらをネットワーク上で伝送することは煩わしい場合があり得る。プロトコルの動作を簡略化するため、(以下に説明するように)、この発明のNDIは、これら特別なコマンドを維持して、コントローラがそれらを維持したり、それらをネットワーク上で送る必要をなくす。このことを考慮して、一実施例では、この発明のNDIは、NDIに接続されるA/DコンバータまたはD/Aコンバータに関連づけられる特別なビットコマンドを含む。図3Aおよび3Bを参照すると、これらコマンドは、元々は記憶装置66に記憶され、プログラム可能である。パワーアップ時、これらの特別なビットコマンドは、コマンドデコーダ102に記憶することができる。
【0074】
図5を参照すると、作動中、特別なコマンドを備えるコンバータを有する遠隔デバイスがアドレス指定される場合、(センサからデータを取得するため、またはアクチュエータの場合は遠隔デバイスを作動させるため)、コントローラは、そのコンバータを備えるデータチャネルのアドレスとともに、適切にフォーマットされたトリガコマンドを送る(ステップ400を参照)。(コマンドのフォーマットは後述する)。データチャネルに関連づけられるNDIがコマンドおよびアドレスを受取ると(ステップ410を参照)、まず、NDIは、アドレス指定された遠隔デバイスが特別なコマンドを必要とするかを判断する。これは、受取ったアドレスをコマンドデコーダに記憶されるデータに関連づけられるアドレスと比較することによって行なう(ステップ420を参照)。アドレスに基づいて、この発明のNDIは、コマンド変換レジスタから適切な特別コマンドを検索する(ステップ430を参照)。次に、特別コマンドは、情報を受取るために、センサの場合はコマンドに対応するアクチュエータを作動させるために、コンバータに適用される(ステップ440を参照)。
【0075】
先に簡単に述べたように、コントローラおよびこの発明のNDIデバイスは、同期モードまたは非同期モードのどちらでも作動することができる。同期モードでは、コントローラは連続する同期クロック信号を与える。同期クロック信号は、バスコントローラからのデータの入力時刻を記録し、コントローラへのデータの出力時刻を記録するために、この発明のNDIデバイスによって使用される。このことによって、バスコントローラは、0ビット/秒から何らかの最大ビットレートまでのどのようなデータレートも選ぶことができる。
【0076】
この発明のNDIデバイスは、コントローラが非同期モードまたは同期モードのどちらで作動しているかを自動的に検出することができる。具体的には、図3A、3Bおよび図6を参照すると、この発明のNDIデバイスは、クロック検出器を使用して、第2の受信器52で受取られる信号を連続的に調べる(ステップ500を参照)。同期クロック信号が存在する場合(ステップ510を参照)、この発明のNDIデバイスは、同期モードで作動し(ステップ520を参照)、コントローラからの同期クロック信号を使用して、データの入力時刻および出力時刻を記録する。しかしながら、この発明のNDIデバイスが第2の受信器52からの同期クロック信号を検出しない場合(ステップ510を参照)、この発明のNDIデバイスは、非同期モードで作動する(ステップ530を参照)。
【0077】
上述のように、非同期モードでは、コントローラはさまざまなビットレートで作動し得る。このことを考慮して、一実施例において、この発明のNDIデバイスは、コントローラが作動しているビットレートを検出する。具体的には、図7を参照すると、この実施例では、この発明のNDIデバイスがコントローラが非同期モードで作動していると判断した後、この発明のNDIデバイスは、コントローラによって伝送されるコマンドおよびデータのビットを監視する(ステップ600を参照)。NDIデバイスは、ビットレートデコーダを使用して、各ビットの受取り間の時間を判断する。伝送間の時間が実質的に同じである予め定められた数のビットが受取られた後(ステップ610を参照)、この発明のNDIデバイスは、NDIデバイスに送られているデータのビットレートを選び、そのビットレートで作動する(ステップ620を参照)。重要なのは、NDIデバイスのビットレートを検出する能力は、ネットワークシステムに電力障害があった場合、またはコントローラが同期モードから非同期モードに遷移した場合に、すばやく復旧するために有利であることである。自動的に同期クロックを検出する特徴および自動的にビットレートを検出する特徴の第2の重要な局面は、それによって、1つの種類のNDIデバイスが異なるモードのネットワーク通信を使用してネットワーク上で通信することが可能となることである。ネットワークシステムの設計者は、ネットワークシステムの特定の用途に最適化したネットワーク通信のモードを選ぶことができる。
【0078】
さらに一実施例では、バスコントローラは、NDIデバイスに或る特定のビットレートでデータを送受信するように命令することができる。バスコントローラは、ビットレート変更コマンドを送り、それに続いてNDIデバイスがこれからそれに変更するビットレートを送ることができる。NDIデバイスは、バスコントローラによって指示されるビットレートで、データをバスコントローラから受取り、バスコントローラに伝送する。さらに、コントローラは、例としてのメッセージを新しいビットレートで送ることができ、この発明のNDIは、実際のコマンドおよびデータが送られる前にその新しいビットレートに変更する。
【0079】
この発明のNDIデバイスのもう1つの利点には、或るネットワークバス上の多くの異なるNDIデバイス上の多くのデータチャネルが同期または非同期モードでバスコントローラに通信している場合に、アナログデータを実質的に同時にサンプリングまたは変換することができる点である。非同期モードでのデータサンプリングまたは変換を同期させる1つの方法は、変換信号84の立上がりエッジ(図3Bを参照)を、コントローラからの変換コマンドの中央エッジが変化したとき、またはその直後にhighにすることによって達成される。プロトコルの中には、変換コマンドをトリガコマンドと呼ぶものがある。プロトコルおよびNDIデバイスが非同期モードでも同時にデータをとり、またはデータを変換する能力は、等時性と呼ばれる。
【0080】
同期データサンプリングの第2の方法は、同期クロック信号を各NDIデバイスから各NDIデバイスに関連づけられる各データチャネルに与えることによるものである。クロック信号は、同期コマンドを使用してバスコントローラによって同期され、NDIデバイスは、図9のタイミングに従ってコマンドに応答して同期する。そのようにして、同期バス信号の分割された一部である周波数を有するクロック信号を使用するデータチャネルのすべては、ほぼ完璧に同期して作動する。
【0081】
インターフェイスに異なる種類のA/DコンバータおよびD/Aコンバータならびに異なる信号調整システムを与え、同期モードおよび非同期モードの両方で作動することに加え、この発明のNDIデバイスは、ネットワークでのデータの伝送におけるオーバーヘッドを省くこともできる。特に、図3Bに示されるように、この発明のNDIデバイスは、データスタック88を含む。NDIデバイスがセンサ遠隔デバイスに接続される場合、データスタックは、入力データスタックである。入力データスタックは、データチャネルから受取ったデータを含む。この場合、入力データスタックに記憶されるデータは、コントローラによって1度に1つのワード(すなわち1度に1つのレジスタ)、またはデータのブロックとして(すなわち一度に複数のレジスタを)読出すことができる。データスタックから一度にデータのブロックを読出すことによって、ネットワークのオーバーヘッドが省かれる。
【0082】
さらに、この発明のNDIデバイスがアクチュエータ遠隔デバイスに接続される場合、データスタックは、出力データスタックである。この場合、出力データスタックは、コントローラによって転送されアクチュエータ・データチャネルに出力されるべきデータを含む。トリガコマンドがアクチュエータに送られると、アクチュエータはデータスタックの最上部のワードのデジタルからアナログへの変換を行ない、次に、NDIデバイスは、スタックをポップし、スタックの最上部の新しいワードをD/Aに伝送する。データワードは、コントローラによって個々にまたはワードのブロックとして出力データスタックに書込むことができる。出力データスタックに、一度に1つではなく、データのブロックを書込むことによって、ネットワークのオーバーヘッドが省かれる。
【0083】
上述の利点に加え、この発明のNDIデバイスにはさらなる利点がある。具体的には、一実施例において、この発明のNDIデバイスは、単純かつ高速でありながら堅牢なデジタル・マルチドロップ・ネットワーク上でデータチャネルが通信することを可能にするプロトコルとともに作動する。どのような適用可能なプロトコルでも、この発明のNDIデバイスとともに使用可能であることを理解されたい。しかしながら、以下に記載するのは、図1に示されるネットワークシステム30で使用される場合に、いくつかの利点を提供する、或る特定のプロトコルである。1つの重要な利点は、プロトコルが単純であるため、NDIデバイスを高レベルプロセッサではなく、ステートマシンとして実現することができることである。
【0084】
特に、プロトコルは、低レベル通信制御インターフェイス(すなわちネットワークコントローラおよびNDIデバイス)を保証するように設計される。プロトコルによって、ネットワーク内で高度に小型化されたコントローラおよびネットワーク・デバイス・インターフェイスを開発することが可能となる。ネットワークコントローラおよびNDIデバイスが、プロトコルとともに作動する特定用途向け集積回路(ASIC)またはFPGAで実現される場合、ネットワークコントローラおよびNDIデバイスは、素早く応答することができかつ最大限のバスの効率を効率良く実現する。バスコントローラまたはNDIデバイスがASICとして実現される場合、バスコントローラおよびNDIデバイスは、非常に小型化できる。
【0085】
この発明のプロトコルは、低オーバーヘッドのコマンド構造も有する。この発明のプロトコルは、固定長のメッセージを使用しない。メッセージの長さは、コマンドに応じて変り得る。このことによって、コマンドを実行するのに必要でない場合、不必要なデータが伝送されるのを排除することができる。さらに、コマンドセットは最低限かつ単刀直入であるため、ユーザは最低限の操作でネットワークバスを介してデータを容易に渡すことができる。
【0086】
上述のように、この発明のNDIデバイスは、固定された低レベル命令セットを有するため、簡略化されたコントローラおよびネットワーク・デバイス・インターフェイスをネットワーク・デバイス上で使用することを場合によっては可能にするプロトコルとともに作動する。特に、低レベルコマンドセットによって、NDIデバイスは、プロセッサまたはマイクロコントローラではなく、ステートマシンとして実現することができる。低レベルコマンドセットがどのように働くかの一例を示す。バスコントローラがNDIデバイスのメモリからデータワードを読出したい場合、これは、セットポインタと呼ばれるコマンドをNDIに送り、次にそのコマンドに続いてそのポインタの値を送る。NDIは、そのコマンドをデコードし、そのメモリアドレスポインタをバスコントローラによって送られた値にセットする。メモリアドレスポインタは、バスコントローラによって送られる値をラッチするレジスタでありさえすればよい。次に、バスコントローラは、メモリワード読出コマンドをNDIデバイスに発行する。NDIデバイスは、そのメモリアドレスポインタによって指し示されるメモリワードにアクセスし、それをバスコントローラに伝送することによって応答する。バスコントローラがNDIのメモリからデータのブロックを読出したい場合、このプロセスを複数回繰返す。
【0087】
コマンドセットが高レベルコマンドセットである場合、上述の読出プロセスは、特別メモリブロック読出コマンドとして実現される。NDIデバイスは、特別メモリブロックにアクセスするためにそのポインタをどこにセットするかを知り、そのポインタをセットし、特別メモリブロックがどれくらい大きいかを知り、次に特別メモリブロックを送ることができる必要がある。このプロトコルは、どこに特別メモリ情報が記憶されているか、および特別メモリ情報のブロックサイズがどれくらい大きいか、どこに特別メモリデータを記憶するかを常に把握するなどのこれらの作業を、NDIデバイスから取除く。これらの作業は、メモリポインタと読書きできるメモリとをセットするように低レベルの命令をつなげる代わりに、バスコントローラによって行なう。
【0088】
上述のように、この発明のNDIデバイスは、固定された低レベルかつ低オーバーヘッドの命令セットを有するプロトコルとともに作動し、このプロトコルは高性能なセンサおよびアクチュエータとともに使用されると、ネットワークバス上の実際のデータレートを向上する。センサおよびアクチュエータをネットワークするためのネットワーク・トラフィックは、通常のコンピュータネットワーク・トラフィックとは異なる。コンピュータネットワークは、1つのコンピュータから別のコンピュータへ大きなデータファイルまたはメッセージを伝送する必要がある。結果として、それらは、堅牢かつエラーのないデータ伝送を保証するため、メッセージに関連づけられるチェックサムおよびブロックサイズを有する。これらコンピュータネットワークプロトコルに関連づけられる、これらのチェックサムおよびブロックサイズ、またはその他のオーバーヘッドは、オーバーヘッドのサイズが合計のメッセージサイズと比較して小さいため、問題にはならない。センサおよびアクチュエータのネットワークトラフィックが異なるのは、多くの場合、ネットワーク上のメッセージの大半が、16ビットのデータのみを備える非常に小型のメッセージであるためである。ブロックサイズ、チェックサムまたはその他の不必要なオーバーヘッドが小型の16ビットデータメッセージに付加されると、チェックサム、ブロックサイズおよびその他のオーバーヘッドは、実際の16ビットデータメッセージよりも多くのビットを有し得る。このことによって、事実上、センサおよびアクチュエータ・ネットワークバスの帯域幅が低減する。この発明のNDIデバイスは、チェックサムおよびブロックサイズなど不必要なオーバーヘッドを短い16ビットのメッセージに付加しないメッセージプロトコルを使用することによって、この問題を解決する。これら短い16ビットのメッセージに付加される唯一のオーバーヘッドは、メッセージの開始を示す同期パターン、フラグビットおよびパリティビットである。パリティビットは、16ビットのメッセージにエラーがないかをチェックするために使用される。フラグビットは、送信するNDIデバイスまたは関連づけられるデータチャネルにエラー状況が存在するかどうかを示す。
【0089】
この発明のプロトコルは、通常、マンチェスタ符号化されたフォーマットで伝送されるが、他のUARTシステムと通信するため、必要であれば、汎用非同期送受信器(UART)フォーマットプロトコルで実現され得る。たとえば、一実施例では、プロトコルは、Bi-Phase Sensor and System(BiSenSys)と称する、RS−485ベースの、マルチドロップ、マンチェスタ符号化されたプロトコルを使用する。BiSenSysは、18ビットの高速かつ高効率のプロトコルで、マンチェスタ符号化を使用するデジタルバス構造上の遠隔デバイスとサブシステムとを接続するために使用する。マンチェスタ符号化を使用する別のプロトコルの例は、MIL−STD−1553である。具体的には、データの各ビットは、1つの検出可能な遷移によって検出可能である(すなわち、「0」はlowからhighと規定され、「1」はhighからlowと規定される)。さらに、各メッセージは、同期パターン、メッセージ本体およびパリティフラグからなる。BiSenSys伝送プロトコルは、同期モードまたは非同期モードで作動可能であり、同期モードでは、1Hz〜10MHzまでのどのデータレートでも作動するように実現可能であり、または非同期モードでは、1.25メガバイト毎秒、2.5メガバイト毎秒、5.0メガバイト毎秒、および10.0メガバイト毎秒で作動するように実現可能である。さらにこの発明のプロトコルは、UARTベースのプロトコルで実現され得る。このプロトコルは、1.0メガビット毎秒のデータレートで作動するように設計され、9ビットメッセージフォーマットおよび非ゼロ回帰(non-return-to-zero)ビット符号化を使用する。
【0090】
ネットワークバスにわたって伝送されるデータフレームには、少なくとも3種類があり、データフレームは、BiSenSysプロトコルとUARTプロトコルとの間で異なる。BiSenSysデータフレームには3種類ある。第1の種類は、コマンドフレームである。コマンドフレームは、コマンド同期パターン、これに続くマンチェスタ符号化された10のアドレスビット、これに続くマンチェスタ符号化された7つのコマンドオペコードビット、およびマンチェスタ符号化された1つのパリティビットからなる。コマンド同期は、バス上の、1と2分の1バスビット期間のhighの状態と1と2分の1ビット期間lowの状態とからなる。
【0091】
第2の種類のフレームは引数フレームである。引数フレームは、データ同期パターンで始まり、これにマンチェスタ符号化された16の引数ビット、マンチェスタ符号化された1つのフラグビット、最後にマンチェスタ符号化された1つのパリティビットが続く。データ同期パターンは、1と2分の1ビット期間のlowと、それに続く1と2分の1ビット期間のhighとからなる。BiSenSysフレームの最後の種類は、データフレームである。データフレームは、データ同期パターンで始まり、これに16ビットのマンチェスタ符号化されたデータが続き、マンチェスタ符号化された1つのフラットビット、マンチェスタ符号化された1つのパリティビットが続く。引数フレームとデータフレームとの唯一の違いは、引数フレームがバスコントローラによって伝送され、データフレームはネットワーク・デバイスによって伝送される点である。引数は、あるコマンドに続いてバスコントローラによってのみ伝送される。引数が続くことを必要とするコマンドは、RHAMIS/BiSenSysプロトコルで規定される。バスクロックがBiSenSys同期モードで使用される場合、これはマンチェスタ符号化されたビットストリームに直交して伝送される。
【0092】
UARTプロトコルの場合、メッセージフォーマットは、3つ以上の11ビットフレームを含む。各メッセージは、発行されるコマンドに応じて、メッセージにつき2つの付加的なオプションのフレームを備えた、メッセージにつき3つの必要なフレームを有する。すべてのフレームの第1のビットは、スタートビット(0にセットされる)である。すべてのフレームの最後のビットは、ストップビット(1にセットされる)である。メッセージの第1のフレームは、UARTプロトコルのためのアドレスフレームである。これは、スタートビット、8ビットのアドレス領域、1にセットされるアドレスビット、およびストップビットの形である。UARTメッセージの第2のフレームは、コマンドフレームである。コマンドフレームは、スタートビット、7ビットのコマンド領域、未使用ビット、0にセットされるアドレスビットおよびストップビットからなる。引数フレームがUARTメッセージに属する場合、それらはコマンドフレームに続く。それらは、スタートビット、それに続く8つの引数ビット、0にセットされるアドレスビット、ストップビットからなる。UARTメッセージの最後のフレームは、チェックサムフレームである。これは、スタートビット、アドレス、コマンドおよび桁上がりを伴わないデータビットの、2を法とした合計である8ビットチェックサム、0にセットされるアドレスビットおよびストップビットからなる。
【0093】
同期モード、非同期モードのどちらでも作動しかつ異なる伝送プロトコルで作動する低レベル命令セットを有するプロトコルを提供することに加え、この発明は、各データチャネルに一意のアドレスを割当てるための方法も提供する。図1に示されるように、典型的なネットワークシステム30には、複数の異なるNDIデバイスに接続される多数のデータチャネルがあり、それらのすべてがバスコントローラと通信するために共通のネットワークバスを使用する。さらに、ネットワーク・デバイスの各々は、NDIデバイスによって命令され得るいくつかのデータチャネルまたはいくつかの作業を有し得る。この発明のプロトコルは、ネットワーク・デバイスの各データチャネルに3つの種類のアドレスを与える。具体的には、各ネットワーク・デバイス上の各データチャネルには、個々の論理アドレス、グローバルアドレス、および設定されている場合、グループマスクを割当てることが可能である。
【0094】
論理アドレスは、ネットワーク・デバイス上の1つのデータチャネルによって、またはネットワーク・デバイスの1つの制御可能な作業によって認識される、アドレスである。一方グローバルアドレスは、すべてのネットワーク・デバイスのすべてのデータチャネルによって認識され、グループアドレスは、すべてのネットワーク・デバイスのすべてのデータチャネルのサブセットによって認識される。データチャネルにはグループアドレスは割当てられない。それらにはグループマスクが割当てられる。グループマスク内の各ビットはグループアドレスに対応する。このようにして、1つの16ビットマスクを使用して、データチャネルを16のグループに割当てることができる。たとえば、グループマスクの第1および第3のビットが1にセットされている場合、データチャネルは、それ自身がグループ1および3に属すると認識する。それは、1または3のいずれかのグループアドレスを有するコマンドメッセージに応答する。これら3つの異なるアドレスは、それらによって、コントローラが、同じネットワーク・デバイス内の、または複数のネットワーク・デバイス内の、1つのネットワーク・デバイスの個々のデータチャネルまたはデータチャネルのグループと通信することが可能となり、またはすべてのネットワーク・デバイスのすべてのデータチャネルと通信することが可能となるため重要である。これらアドレスの各々は後に詳しく説明する。
【0095】
論理アドレスおよびグループアドレスの判断は、どのような方法を選択して行なってもよい。好ましい方法は、2000年12月8日出願の「共通のバスを介して遠隔デバイスをデジタル方式で制御するためのネットワークコントローラ(NETWORK CONTROLLER FOR DIGITALLY CONTROLLING REMOTE DEVICES VIA A COMMON BUS)」と題される、米国仮特許出願番号第60/254,137号に記載される。この方法は、各ネットワーク・デバイスに関連づけられる汎用一意識別子(Universal Unique Identifier;UUID)を使用する。UUIDコードは、すべてのネットワーク・デバイスに対して一意である80ビットのコードであり、デバイスが製造された場所および日付に基づく。
【0096】
図3Aを参照すると、通常、この発明のネットワーク・デバイスのためのUUIDは、NDIデバイスの記憶装置66に記憶される。論理アドレスおよびグループ後の判断中、コントローラは、この発明のNDIデバイスにさまざまなコマンドを送り、それらにそれらのそれぞれの記憶装置にアクセスし、UUIDの個々のビットを分析し、或るビットが1か0であるかに基づいて応答するかまたは沈黙したままでいるように命令する。このことによって、バスコントローラは、一度に1つのネットワーク・デバイスずつ、すべてのネットワーク・デバイスのUUIDを発見することができる。ネットワーク・デバイスのUUIDを見つけるとその直後に、バスコントローラは、そのネットワーク・デバイス上のすべてのデータチャネルに論理アドレスおよびグループマスクを割当てる。
【0097】
図8は、バスコントローラの制御の下、NDIデバイスを使用して、ネットワーク・デバイスがそれ自身をバスコントローラに対して一意に識別するために行なうステップのフローチャートである。デバイス・インベントリ・セッションを開始するため、NDIデバイスは、デバイス・インベントリ可能化(Device Inventory Enable)コマンドを使用して可能化される。これによって、NDIはデバイス・インベントリ・モードに入る(ステップ700を参照)。アドレス「0」(すべてのデバイスのために確保されたグローバルアドレス)がアドレス領域で指定されると、バス上のすべてのネットワーク・デバイスは、それ自身をデバイス・インベントリ・モードにする。現在割当てられている論理アドレスがアドレス領域で指定されると、そのネットワーク・デバイスは、それ自身をデバイス・インベントリ・モードにする。現在割当てられているグループアドレスがアドレス領域で指定されると、そのグループに属するすべてのネットワーク・デバイスは、それら自身をデバイス・インベントリ・モードにする。
【0098】
UUIDワードサーチ(word search)中、デバイス・インベントリ・コマンド内のさまざまな関数コードが使用される。新しいUUIDワードサーチ関数コードを備えるデバイス・インベントリ・コマンドは、すべてのデバイス・インベントリ・セッション可能化装置をUUIDワードサーチモードにセットする(ステップ705を参照)。バス上のネットワーク・デバイスは、UUIDワードサーチモードでなければ、UUIDワードサーチで競合しない。ワードサーチモードに入るようにと命令された直後、NDIデバイスは、UUIDの最下位ビットを第1のレジスタへロードし、かつ「1」を第2のレジスタにロードすることによって、自動的に進行する(ステップ710を参照)。NDIデバイスがUUIDワードサーチモードである場合、それらは、2つのUUIDビット競合関数コードに応答する。
【0099】
マスターコントローラは、UUIDビット競合(Bit Competition)、ノー・ドロップアウト(No Dropout)関数コードを備えるデバイス・インベントリ・コマンドを発行する。すべてのNDIデバイスは、このコマンドに基づいて判断を行なう(ステップ720を参照)。NDIデバイスは、ステップ730に進み、レジスタ1内のそのビットに基づいて判断を行なう。このビットが「1」であれば(ステップ730を参照)、ネットワーク・デバイスは沈黙したままである。このビットが「0」である場合、ネットワーク・デバイスはUUIDパルスを伝送する(ステップ740を参照)。次に、ネットワーク・デバイスは、評価済みのビット(「1」または「0」のどちらか)をビットレジスタ2に移動し、その次のUUIDビットにアクセスし、それをビットレジスタ1にロードする(ステップ760を参照)。
【0100】
マスターコントローラは、バス上で伝送されるUUIDパルスを聞く。マスターコントローラがUUIDパルスを聞いた場合、少なくとも1つのネットワーク・デバイスがその現在のUUIDビットに「0」を有することがわかる。マスターコントローラが少なくとも1つのUUIDパルスを聞いた場合、それが発行する次のコマンドは、UUIDビット競合、1のドロップアウト(1's Dropout)関数コードを備えるデバイス・インベントリ・コマンドである。NDIデバイスは、そのコマンドを解釈し、判断を行なわなければならない(ステップ720を参照)。ネットワーク・デバイスがこのコマンドおよびコードを聞いた場合、レジスタ2のそのUUIDビットを見る(ステップ780を参照)。このビットが「1」である場合、ネットワーク・デバイスは、現在のUUIDビット競合モードを出て、UUIDワードサーチでの競合を終了する。レジスタ2のビットが「0」である場合、ネットワーク・デバイスは、レジスタ1のビットを見る(ステップ730を参照)。それが「0」である場合、ネットワーク・デバイスはUUIDパルスを伝送する(ステップ740を参照)。このビットが「1」である場合、ネットワーク・デバイスは沈黙したままである。次に、ネットワーク・デバイスは、レジスタ1のビットをビットレジスタ2に移動し、その次のUUIDビットにアクセスし、それをビットレジスタ1にロードする(ステップ780を参照)。
【0101】
バス上でマスタコントローラにどのようなUUIDパルスも聞こえない場合、マスタコントローラは、依然としてUUIDワードサーチモードにあるすべてのネットワークデバイスがビットレジスタ2内に「1」を有することを認識する。これに応答して、マスタコントローラが発行する次のコマンドは、UUID Bit Competition、No Dropout 関数コードを伴った Device Inventory コマンドである。ネットワークデバイスがこのコマンドを受取ると、そのレジスタ内に何があるかに関係なく、競合したままとなる。このコマンドに応答して、競合するすべてのデバイスは、ビットレジスタ1を見る(ステップ730参照)。それが「0」であると、ネットワークデバイスはUUIDパルスを送信する(ステップ740参照)。それが「1」であると、ネットワークデバイスは使用されないままとなる。ネットワークデバイスは、レジスタ1内のビットをビットレジスタ2内に移し、その次のUUIDビットにアクセスして、それをビットレジスタ1内にロードする(ステップ760参照)。
【0102】
このセクションで説明されるUUID Bit Competition は、80のUUIDビットのすべてに対して繰返される。マスタコントローラは、全部合わせて81のUUID Bit Competition 関数コードを発行しなければならない(ステップ750参照)。マスタコントローラは、バス上の最後のネットワークデバイスが、勝った最終ビットを誰が有したかを決定できるように、81番目のUUID Bit Competition 関数コードを発行しなければならない。
【0103】
UUID Bit Competition 関数コードを伴った Device Inventory コマンドが、全部合わせて81回にわたって発行された後に、UUIDワードサーチモードで残されるのは、1つのネットワークデバイスのみである。このネットワークデバイスが勝者である(ステップ770参照)。このネットワークデバイスは、この時点でバスコントローラに一意に識別されており、特定の記憶場所の内容で応答する(ステップ780参照)。特定の記憶場所の上位のバイトはプロトコルの改訂数を保持し、下位のバイトはネットワークデバイス上のデータチャネル数である。勝ったネットワークデバイスおよびバスコントローラは、このネットワークデバイスが、全81ビットの競合に勝ったことによって勝利したことを認識している。
【0104】
勝ったデバイスが81番目のUUID Bit Competition 関数コードを受取ると、このデバイスは、このデバイスがそのメモリ内に記憶したプロトコルのバージョン数およびチャネル数を含むバイフェイズ準拠データフィールドで応答する(ステップ780参照)。バスコントローラは、勝ったデバイスの論理アドレスチャネル割当を決定するために、この情報を用いることができる。勝ったネットワークデバイスは、その論理アドレスおよびグループマスクの記憶場所を保護しない(ステップ790参照)。バスコントローラは、すぐにひき続いて、論理アドレスおよびグループマスクを割当てる(ステップ800参照)。データチャネルが複数のチャネルを含む場合、マスタコントローラは、各チャネルに論理アドレスとグループマスクとを割当てる(ステップ810参照)。論理アドレスおよびグループマスクが割当てられた後に、ネットワークデバイスは、デバイスインベントリモードを終了する。バスコントローラは、すべてのネットワークデバイスが発見され、かつ、論理アドレスおよびグループマスクが各チャネルに割当てられるまで、UUIDワードサーチを繰返す。バスコントローラは、バス内のUUIDが、仮に発見されるとしてすべて1’sである場合に、全デバイスを発見したことになると認識する。すべて1のUUIDを有するネットワークデバイスは存在しない。
【0105】
上述のように、各ネットワークデバイスに対する各チャネルには、データチャネルを一意に識別する論理アドレスが供給される。さらに、多数のデータチャネルをアドレス指定するグループアドレスと、全ネットワークデバイスの全チャネルをアドレス指定するグローバルアドレスとが存在する。グローバルアドレスは、グローバルデータおよびコマンドを交換するために用いられる。グループアドレスは、ネットワークデバイスの複数のデータチャネルによって認識されるアドレスである。グループアドレスにより、1つ以上のデータチャネルは、同じコマンドに同時に応答する。1つのデータチャネルのみをグループアドレスに割当てることができる。グループアドレスと関連するのが、アドレスデコーダ100内に記憶されるグループマスクである。グループマスクは、16ビットワードであり、1にセットされた各ビットは、データチャネルが属するグループを示す。
【0106】
一実施例における一例として、グローバルアドレスには0000hexが割当てられる。この実施例において、アドレス0000hexが送信されると、NDIデバイスのすべてがこのコマンドに従う。これは、一般に、システムのリセットまたはシステムのテストのために用いられる。さらに、一実施例において、グループアドレスは、0001hexから000fhexの範囲で選択される。この実施例において、この範囲のアドレスがNDIデバイスによって受取られると、それは、グループアドレスと、アドレスデコーダレジスタ100内に記憶されたグループマスクとを比較する。グループアドレスに対応するグループマスク内のビットがセットされると、この発明のNDIデバイスデータチャネルは、そのグループアドレスに関連するコマンドを解釈して、それに従う。たとえば、デバイスインベントリレジスタ内に記憶されたグループマスクが100000001100binである場合、NDIデバイスは、グループアドレス000fhex、0003hex、および0002hexに属する。
【0107】
グループアドレススキームは、さまざまなサンプル速度でセンサまたはアクチュエータのグループに対して、時間で決定されるトリガをユーザが設定できるように設計される。表1は、異なるサンプル速度を有するセンサのグループと、それらのグループ割当とを示し、表2は、デバイスをポーリングするためのシーケンスを示す。これらの表から分かるように、データチャネルは、それらが同時に、かつ異なったサンプル速度でトリガされ得るように、ともにグループ化され得る。
【0108】
【表1】
【0109】
【表2】
【0110】
グループアドレスに関しては、コントローラがグループアドレスを送信すると、この発明のアドレスデコーダ100およびコマンドデコーダ102がコマンドのアドレス部分をデコードし、グループアドレスと、それ自体に記憶されたグループマスクとを比較する。ネットワークデバイスがグループアドレスの支配下にあることをグループマスクが示すと、そのグループアドレスと関連するコマンドを、適切なデータチャネルがネットワークデバイス上で実行する。
【0111】
上述のように、プロトコルとともに用いられるアドレス指定方法により、コントローラは、コマンドおよびデータをネットワークデバイスの1つまたはいくつかのいずれかに送信することができ、データの異なった形式は、BiSenSysまたはUARTのどちらが用いられているかに依存して、送信される。以下に、ネットワークバスを介して通信するために一般に用いられるコマンドを示す。上述のように、この発明のプロトコルは、コマンドおよび応答メッセージが、任意のコマンドを実行するのに必要とされるデータ量に依存して長さを変化させ得るように、効率を最大にするように設計される。このことを達成するために、この発明のプロトコルは、3レベルのユーティリティを設ける。これらのコマンドを表3に示す。
【0112】
【表3】
【0113】
コマンドの1つのレベルはサービスコマンドである。サービスコマンドは、ネットワークハウスキーピング、ネットワーク・デバイス・インターフェイス状態、電源管理、較正、およびバスマスタ裁定のためのものである。これらのコマンドを、以下に簡潔に説明する。たとえば、 No Op コマンドは、この発明のNDIデバイスに対し、アクションを取らないように命令する。No Op コマンドは一般に、バス制御を維持するために、演算の初期化において、またはマスタもしくはネットワークコントローラによって、用いられる(図1参照)。
【0114】
Built-In-Test(BIT)、E−Calibration、およびZ−Calibration コマンドは、ネットワークバスに接続されたNDIデバイスにセルフテストを行なうために用いられる。たとえば、BITコマンドは、NDIデバイスに対し、内部回路のチェックを行なうよう指令する。E−Calibration コマンドは、励起較正を強制して、センサネットワークデバイスからの入力が基準電圧に置換えられ、NDIデバイスが基準電圧におけるNDIデバイスの較正値を測定するために読出しを行なう。同様に、Z−Calibration コマンドは、ゼロ較正の測定を開始し、センサデータチャネルに対する入力が短絡される。NDIデバイスは、データチャネルのオフセット値を測定するために読出しを行なう。
【0115】
プロトコルは、2種類のリセットコマンド、すなわち、Reset およびSynchronize も含む。Reset コマンドは、ネットワークバスに接続された、この発明のネットワーク・デバイス・インターフェイスのすべてをパワーアップ状態に初期化する。この Reset コマンドは一般に、必要時にバスおよびネットワークデバイスをリセットして、ネットワークバスの制御を取り戻すために、コントローラによって用いられる。
【0116】
Synchronize コマンドは、いくつかのNDIデバイス間で同期を確立して維持するために重要なコマンドである。特に、上述のように、A/DおよびD/Aコンバータの中には、コントローラによって供給される同期クロック信号とは異なる、連続したクロック信号を必要とするものがある。このクロック信号は、ローカル発振器からのクロック信号または同期バスクロック信号のいずれかを分割する分割器によって供給される。この分割されたクロック信号は、データを変換するために、コンバータによって用いられる。分割器はコンバータによって必要とされる適切なクロック周波数を供給するが、異なったNDIデバイス上にこれらの異なった分割器が存在することにより、1つのNDIデバイス上のコンバータが別のNDIデバイス上のコンバータと同期されないことがあり得る。特に、コンバータのすべては同一周波数で作動できるが、分割器は位相がずれていることがあり得る。
【0117】
このことに照らして、Synchronize コマンドは、複数のNDIデバイス間で、分割されたクロック信号を同期させる。特に、図9を参照すると、分割器が同期クロック信号を用いており、かつ、Synchronize コマンドが発行されると、NDIデバイスは、そのクロック分割器を制御して、クロック信号の生成をリセットし、再開する。NDIデバイスのすべてが、同期コマンドで用いられるグループアドレスまたはグローバルアドレスに従って、それらのクロック分割器の同じリセットおよび再開を同時に行なう。
【0118】
図11a、図11b、および図11cは、この発明のNDIデバイスが、どのように取付けられて異なるデータチャネルを制御することができるかの代替的実施例を示す。データチャネルの中には、図11Aに示されるように、データを正確なタイミングで取得するために、NDIデバイスから変換信号のみを必要とするものがある。データチャネルの中には、図11Bにおけるように、データを正確なタイミングで取得するために、同期された分割クロック信号および可能性として同期信号のみを必要とするものがある。データチャネルの中には、図11Cにおけるように、正確なタイミングでデータを取得するために、変換信号および分割クロック信号の両方を必要とし得るものがある。
【0119】
図11A〜図11Cを参照すると、Synchronize コマンドの使用が、異なるネットワークデバイス間のデータチャネルにおいてスイッチド・キャパシタ・フィルタ126、シグマ/デルタA/Dコンバータ120、またはデジタルフィルタ118等をすべて同期に作動させることに関して示される。クロック分割器がクロック信号を生成するためにローカル発振器を分割する場合に、この分割器は、同期コマンドのパリティビットの中央エッジにてリセットし、再開する。これにより、複数のNDIデバイス間のクロック分割器は、ともに同期する。しかしながら、ローカル発振器の周波数の変化により、クロックが経時的に位相を外れてドリフトすることを認識されたい。クロック分割器に対するソースがバスクロックである場合、クロック分割器は図9のタイミングに従って同期し、分割されたクロックは、その後同期して稼働し続ける。NDIデバイスの本実施例は、シグマ/デルタA/Dコンバータ120、デジタルフィルタ118、または他のデバイスのリセットまたは同期を行なうために、同期信号116、124、および128をそれに取付けられたデータチャネルに与える。
【0120】
表3を参照すると、プロトコルは、Wake および Sleep コマンドも含む。Sleep コマンドは、ネットワークデバイスの特定の部分をパワーダウンさせ、Wake コマンドは、それらをパワーアップする。さらに、プロトコルは、Read Status Register コマンドを含む。このコマンドは、NDIデバイスの状態レジスタの読出しを生じ、ネットワークデバイスが忙しいか否か、それが特定のコマンドを指示するか否か、コントローラがデータスタックに要求したデータが多すぎるかまたは少なすぎるか、メッセージ送信エラーが生じたか否か、メモリが保護されていないか否か等の情報を供給する。Control Pass コマンドは、ネットワークバス上に2つ以上のバスコントローラがある場合に、どのバスコントローラがバスの制御下にあるかを確立するために、マスタおよびネットワークコントローラによって用いられる。さらに、Baud Select コマンドは、非同期モードで作動している際にネットワークバス上のボーレートを変更するために、コントローラによって用いられ得る。
【0121】
Device Inventory Enable コマンドおよび Device Inventory コマンドは、各ネットワークデバイスの一意な識別、ならびに論理アドレスおよびグループマスクのデータチャネルへの割当に関して上で論じた。Device Inventory Enable コマンドは、一覧にされるべきネットワークデバイスのグループを選択する。Device Inventory コマンドは、ネットワークデバイスの識別ならびに論理アドレスおよびグループマスクの割当に関するほとんどのアクションを制御するために用いられる。このコマンドは、コマンドのアドレスフィールドが、さまざまなデバイスインベントリ関数をデバイス内に方向づけるために用いられる点において異なる。たとえば、これらの関数は、新規の Word Search 競合に入ること、ならびに No Dropout および 1's Dropout と関連するアクションを含む。さらに、このコマンドは、Word Search に勝ったデバイスのメモリから読出すこと、ならびに論理アドレスおよびグループマスクの書込みを含む。
【0122】
コマンドの第2の種類はデータタイプコマンドである。これらのコマンドは、時間で決定されるデータ取得および制御に適合される。ネットワーク効率は、NDIデバイスが、1つのデータポイントを直接動かすか、または規定された長さのブロック転送として2つ以上のデータポイントを動かすことを可能にすることによって最大にされる。たとえば、Trigger コマンドは、センサデータチャネルで入来するデータの測定を開始するか、または、アクチュエータのデータチャネルで物理量へのデータ変換を生じるために、コントローラによって用いられる。図3Bを参照すると、この発明のネットワーク・デバイス・インターフェイスのチャネルの各々は、入力データレジスタ89および入力データスタック88を含む。Trigger コマンドがNDIデバイスによって受取られると、入力データレジスタの内容は、その入力データスタックの上部にプッシュされる。次に、それはデータチャネルから新規の読出しを行なう。読出しが終了すると、新規の読出し値は、入力データレジスタ内に存在する。バスコントローラは通常、入力データスタックからデータを読出す。
【0123】
入力データスタックからデータを取得することにより、バスコントローラに送られるセンサ読出し値の1つ以上のサンプルのレイテンシが生じるが、この配置により、Read-in-data-stack コマンドが、Trigger コマンドの直後にセンサデータチャネルに発行され得る。Read in-data stack コマンドは、入力データスタックからデータを読出す。このことは、次いで、ネットワークバス帯域幅を最大限に用いることを可能にし、これは、センサデータチャネルが長い変換時間を有する場合に重要である。このことは、また、ユーザが書込まなければならない Trigger および Read コマンドの組を単純化する。なぜなら、入力データスタックから読出す前に、休止を含む必要がないからである。
【0124】
Read In-Data Register Word コマンドは、それがデータチャネルから利用可能になった直後に入力データレジスタからのデータの読出しを可能にする。バスコントローラは、データが有効になる前に、このレジスタから読出しを試みる必要がない。ネットワークデバイスがアクチュエータである場合、NDIデバイスは、出力データスタックの上部においてデータを値に変換することを指令し、次に、出力データスタックをポップする。ここに図示されていないNDIデバイスの現時点の実施例において、NDIデバイスに出力データスタックは存在しない。データはバスコントローラからNDIデバイスに送られて、データスタックを通過せずにD/Aコンバータまたはデータチャネルに直接至る。しかしながら、NDIデバイスに接続されたD/Aまたはデータチャネルは、1スタックワードのサイズの出力データスタックとして働く、データを保持するためのレジスタを有する。
【0125】
上で論じたように、Trigger および Read コマンドは、データチャネルの測定サイクルを開始して、前の測定結果をネットワークバス上で直ちに送信するために用いられる。このコマンドに応答して、この発明のNDIデバイスは、同時に、入力データレジスタの内容を入力データスタック上にプッシュし、新規の測定サイクルを開始し、入力データスタックの上部の内容の送信を始める。入力データスタックへのプッシュは、コマンドのデータ同期パターンの送信前および送信中に生じる。このようにして、前の測定結果は、有効となって、NDIデバイスの送信機部分が送信のためにそれにアクセスする際に、データスタックに存在することになる。次に、新規の測定値が取られる間に、データサンプルがネットワークバスを介して送信される。
【0126】
読出しコマンドに関し、Read In-Data Register Word コマンドは、入力データレジスタから直接に読出しを開始する。NDIデバイスは、入力データレジスタの内容をネットワークバス上に配置する。Read In-Data Stack Word コマンドは、入力データスタックの上部からデータワードを読出すために用いられる。この場合、この発明のNDIデバイスは、データスタックから最新のデータワードをネットワークバス上に出力することによって応答し、より古いデータがスタックの上部にシフトされる。
【0127】
図3Bに示されるように、この発明のNDIデバイスの各チャネルと関連するデータスタックは、いくつかのレジスタを含む。入力データまたは出力データスタック上にいくつの有効なデータワードが存在するかを決定するために、Query In-Data/Out-Data Stack Depth コマンドが用いられる。この場合、この発明のNDIデバイスは、そのスタック深さレジスタ内の有効データワード数を記憶する。このレジスタの値は、バスコントローラによって指令されると、NDIデバイスによってバスコントローラに送信される。
【0128】
Write Out-Data Stack Word コマンドは、この発明のNDIデバイスに対し、データワードを出力データスタックの上部に書込ませる。さらに、Write Out-Data Stack Word/Acquire To In-Data Register コマンドは、さらに、NDIデバイスに対し、同時に、データチャネルからデータを取得させ、それを入力データレジスタ内に入れさせる。データチャネルへの出力信号が、データチャネルからNDIへの出力に接続される場合は、このコマンドを、アクチュエータに送信されたデータをバスコントローラにエコーバックするために用いることができる。Write Out-Data Stack Word と同様に、Write Out-Data Stack Block コマンドは、NDIデバイスに対し、複数のデータワードを出力データスタックに書込ませる。
【0129】
サービスおよびデータタイプのコマンドに加え、この発明のプロトコルは、メモリコマンドも含む。これらのコマンドは、それに対してデータの書込みまたは読出しが行われ得る、特定の規定された記憶場所または関数へのアクセスを可能にする。これにより、ランダムアクセスデータブロックは、オーバーヘッドをほとんど伴なわずに、システム間で効率よく転送され得る。それはまた、直接メモリアクセスおよび/または1つ以上のデータバッファブロックの移動も可能にする。
【0130】
たとえば、Set Memory Pointer コマンドは、NDIデバイス内にメモリアドレスポインタをセットする。Read Memory Word With Current Pointer コマンドは、メモリアドレスポインタによってポイントされたメモリから1つのワードを読出すために用いられる。Read Memory Word With Current Pointer は、メモリアドレスポインタの現在の値によってポイントされたメモリワードで開始するメモリからデータワードのブロックを読出すために用いられる。コマンドとともにNDIデバイスに渡される引数は、NDIデバイスに対し、いくつのデータワードが読出されるべきであるかを教える。各メモリワードがNDIデバイスによってバスコントローラに送信された後に、メモリポインタは、自動的に1ずつインクリメントされる。次に、次のメモリワードが送信される。このプロセスは、バスコントローラによってリクエストされた数のメモリワードが送信されるまで繰返される。
【0131】
この発明のプロトコルはまた、書込みメモリコマンドも含む。具体的に、Write Memory Word With Current Pointer コマンドは、メモリ内に1ワードを書込む。NDIデバイスは、コマンドを伴う引数を、メモリアドレスポインタによって現時点でポイントされた場所でメモリに書込む。その一方で、Write Memory Block With Current Pointer コマンドは、データワードのブロックをメモリ内に書込む。この発明のNDIデバイスは、コマンドを伴う引数を、メモリアドレスポインタによって現時点でポイントされた場所で始まるメモリ内に書込む。各ワードが書込まれると、メモリアドレスポインタは、1ずつインクリメントされる。このプロセスは、ワードのすべてがメモリ内に書込まれるまで繰返される。
【0132】
上述のコマンドと同様に、この発明のプロトコルは、コマンドとともにコントローラによって送信されるポインタを用いて、データのブロックおよびワードをメモリから読出し、メモリに書込むためのコマンドを含む。これらのコマンドは、上述のものと同様に作用するが、例外として、ポインタは、コマンドに続く引数として供給される。これらのコマンドは、Read Memory Word With Passed Pointer、Read Memory Block With Passed Pointer、Write Memory Word With Passed Pointer、および Write Memory Block With Passed Pointer である。
【0133】
上述のように、この発明のNDIデバイスは、コントローラとさまざまなネットワークデバイスとの間でネットワークバスを介した、コマンドおよびデータのデジタル通信を供給する。図10を参照すると、この発明のNDIデバイスを実現するネットワーク化システムが、航空機10において示される。この実施例では、重要な構造上のさまざまな場所を監視するために、ネットワークが用いられる。航空機には、翼付根、翼表面、尾翼付根、尾翼ケーブル、および着陸装置の歪み等の歪み12、ならびに主翼端および尾翼端の加速度等の加速度14を測定するためのネットワークデバイスが配置される。さらに、ネットワークは、音響疲労に対する重要な胴体圧に加え、レーダ、着陸装置、および着陸端部に対する重要な腐食箇所18等のさまざまな重要な構造上の場所における圧力、ならびにエンジンの外枠の温度20を監視するためのセンサ16を含む。この実施例において、ネットワークデバイスのすべては共通バスに接続され、それにより、過剰な配線をなくす。さらに、データおよびコマンドは、デジタル式に送信されて、雑音による影響が低減される。
【0134】
加えて、NDIデバイスに対する好ましいプロトコルは、NDIデバイスの小型化を可能にする助けとなるように、ネットワークデータビットにマンチェスター符号化を用いる。非同期のシリアルデータを受信するあらゆるデバイスにおいては、それが、シリアルなデータストリームからデータシーケンスのタイミングを取得する能力を有していなければならないことを理解されるべきである。通常、シリアルな非同期データの受信機はローカル発振器を有しており、その受信機に動作をさせ、かつ、シリアルなデータからタイミング情報を取り戻させなければならない。タイミング情報が抽出されると、非同期受信機は、或る速度で、これらの速度、すなわち所与のこのローカル発振器の周波数から或る一定のプラスまたはマイナスの偏差で、シリアルなデータを受信することができる。シリアルなデータのマンチェスター符号化により、各ビットの中心において、ハイからローまたはローからハイへの遷移を生じる。これにより、シリアルなデータストリームからの必要なタイミング情報の抽出が容易となる。マンチェスター符号化されたシリアルなデータストリームからのタイミング情報の抽出が、非常に容易であるために、ローカル発振器に基づいた、期待されたデータ速度からの比較的大きな偏差を許容することができる。期待されたデータ速度からの比較的大きな偏差に対するこのような許容性により、各NDI受信機は、精度の低いローカル発振器を用いてもマンチェスター符号化されたデータを受取ることができる。精度の低いローカル発振器は、極めて小さく形成することができる。適切なローカル発振器の本実施例は、僅か約1×1.5ミリメートルである。これにより、小型のNDIデバイスを形成する助けとなる。
【0135】
上述の説明および関連する図面に示された教示の恩恵を受ける、この発明が属する当該技術の当業者は、この発明の多くの変更例および他の実施例を思いつくであろう。したがって、この発明が、開示された特定の実施例に限定されず、変更例および他の実施例が前掲の請求項の範囲内に含まれることを意図するものと理解されたい。特定の用語がこの明細書で用いられているが、それらは限定するためではなく、一般的な説明のためにのみ用いられる。
【図面の簡単な説明】
【図1】 図1は、この発明の一実施例による、ネットワークバスを介してコントローラと複数のデータチャネルとの間でコマンドおよびデータをデジタル方式で伝送するためのネットワークシステムのブロック図である。
【図2】 この発明の一実施例による、ネットワークバスを介してコントローラと複数のデータチャネルとの間でコマンドおよびデータをデジタル方式で伝送するために行なわれる動作のブロック図である。
【図3A】 この発明の一実施例による、ネットワークバス上でデータチャネルとコントローラとの間でデジタル方式でコマンドおよびデータを通信するためのNDIデバイスの一般的なブロック図である。
【図3B】 この発明の一実施例による、ネットワークバス上でデータチャネルとコントローラとの間でデジタル方式でコマンドおよびデータを通信するためのNDIデバイスの一般的なブロック図である。
【図4】 この発明の一実施例による、遠隔デバイスからデータを検索するためにNDIが行なう動作のブロック図であり、NDIデバイスが同時に複数の作業を行なう一方、同時にバスコントローラと通信する能力を示す。
【図5】 この発明の一実施例による、コントローラから遠隔デバイスに送られたコマンドを、NDIに接続されるコンバータによって使用される特別なコマンドに変換して、コントローラが遠隔デバイスと通信できるようにするために行なわれる動作のブロック図である。
【図6】 この発明の一実施例による、コントローラが同期モードまたは非同期モードのどちらで作動しているかを判断するために行なわれる動作のブロック図である。
【図7】 この発明の一実施例による、コントローラがコマンドおよびデータを伝送しているビットレートを判断するために行なわれる動作のブロック図である。
【図8】 この発明の一実施例による、バスコントローラが論理アドレスおよびグループアドレスをネットワーク・デバイスに割当てているときに、NDIによって行なわれる動作のブロック図である。
【図9】 この発明の一実施例による、複数のNDIデバイスを通じてネットワークに装着される複数のデータチャネルのフリーランニングブロックを同期させるために、NDIデバイスによってデータチャネルに与えられる内部フリーランニングクロックの同期を示すグラフである。
【図10】 航空機で実現される、この発明の一実施例による、電気的ネットワークシステムの概略図である。
【図11A】 この発明の一実施例による、NDIデバイスからの変換信号を使用して正しいタイミングでデータを取得する逐次近似A/Dへの、この発明のNDIデバイスの接続のブロック図である。
【図11B】 この発明の一実施例による、正しいタイミングでデータを取得するため、同期された分割クロックを使用し、同期信号を使用する可能性もあるデジタルフィルタおよびデシメータならびにシグマ/デルタA/Dへの、この発明のNDIデバイスの接続のブロック図である。
【図11C】 この発明の一実施例による、スイッチド・キャパシタ・フィルタを備える逐次近似A/Dおよび信号調整への、この発明のNDIデバイスの接続のブロック図であり、スイッチド・キャパシタ・フィルタは、正確なタイミングでデータを取得するために変換信号および分割されたクロック信号の両方を必要とする。
Claims (17)
- バスコントローラと複数のデータチャネルとの間で共通デジタルバスを介して通信するための方法であって、
同期モードと非同期モードとを含む群から選択されたモードに従い、前記バスコントローラから少なくとも1つのデータチャネルに第1のメッセージを選択的に送信するステップと、
前記少なくとも1つのデータチャネルにて前記第1のメッセージを受信するステップと、
前記第1のメッセージが前記少なくとも1つのデータチャネルによって受信されると、前記第1のメッセージが送信されたモードを判断するステップと、
前記第1のメッセージが以前に送信されたモードと同一のモードに従い、前記第1のメッセージに応答して、前記少なくとも1つのデータチャネルから前記バスコントローラに第2のメッセージを送信するステップとを含み、
選択的に送信する前記ステップは、前記同期モードが選択される場合に、前記共通デジタルバスを介して前記バスコントローラから前記少なくとも1つのデータチャネルにメッセージを送信しながら、前記バスコントローラから前記少なくとも1つのデータチャネルに同期クロック信号を同時に送信するステップを含み、
選択的に送信する前記ステップは、前記非同期モードが選択される場合に、同期クロック信号を送信することなく、予め定められたビットレートで、前記共通デジタルバスを介して前記バスコントローラから前記少なくとも1つのデータチャネルにメッセージを送信するステップを含み、
選択的に送信する前記ステップは、前記非同期モード中に、1と0との間で遷移のない状態にクロック信号を維持するステップをさらに含む、方法。 - 前記モードを判断する前記ステップは、
前記少なくとも1つのデータチャネルによって受信されると、同期クロック信号が存在するかどうかを判断するために、同期クロック信号入力を調査するステップと、
前記同期クロック信号が存在する場合に、前記同期モードに従って前記第1のメッセージが送信されたと判断するステップと、
同期クロック信号が存在しない場合に、前記非同期モードに従って前記第1のメッセージが送信されたと判断するステップとを含む、請求項1に記載の方法。 - 前記モードを判断する前記ステップは、前記同期クロック信号の存在を判断することができない場合に、前記第1のメッセージが前記非同期モードに従って送信されたという判断をデフォルトで選択するステップをさらに含む、請求項1に記載の方法。
- 前記第2のメッセージを送信する前記ステップは、
前記第1のメッセージが前記同期モードで送信された場合に、前記同期クロック信号と同期させて前記第2のメッセージを送信するステップと、
前記第1のメッセージが前記非同期モードで送信された場合に、前記第1のメッセージと同一の、予め定められたビットレートで前記第2のメッセージを送信するステップとを含む、請求項2に記載の方法。 - 前記バスコントローラが前記非同期モードで作動する場合に、後の第1のメッセージが送信される予め定められたビットレートを規定する前記バスコントローラから、ボー選択コマンドを受信するステップをさらに含む、請求項1に記載の方法。
- 前記第2のメッセージが前記データチャネルから送信された速度と同一のビットレートで、前記バスコントローラにて前記第2のメッセージを受信するステップをさらに含む、請求項1に記載の方法。
- 各データチャネルに対する複数のビットを含むマスクを構成するステップをさらに含み、
前記マスクの各ビットは、それぞれのグループと関連し、それぞれのデータチャネルが前記グループのメンバーであることを示す第1の状態と、前記それぞれのデータチャネルが前記グループの非メンバーであることを示す第2の状態とを有し、前記方法はさらに、
前記マスクを前記それぞれのデータチャネルに転送するステップをさらに含み、
前記第1のメッセージを選択的に送信する前記ステップは、前記バスコントローラから、予め定められたグループアドレスを有するデータチャネルのグループに第1のメッセージを送信し、
前記方法は、前記それぞれのデータチャネルに関連する前記マスクを分析することにより、前記それぞれのデータチャネルが、前記予め定められたグループアドレスを有する前記グループのメンバーであるかどうかを各データチャネルにて判断するステップと、
前記それぞれのデータチャネルが前記予め定められたグループアドレスを有する前記グループのメンバーである場合のみに、前記第1のメッセージを処理するステップとをさらに含む、請求項1に記載の方法。 - 前記マスクを構成する前記ステップは、それぞれのデータチャネルに対するマスクを、前記それぞれのデータチャネルが多数のグループのメンバーであり得るように構成するステップを含む、請求項7に記載の方法。
- 各データチャネルが個々にもアドレス指定可能であるように、各データチャネルに対して異なる論理アドレスを確立するステップをさらに含む、請求項7に記載の方法。
- 共通デジタルバスを介して、関連するデータチャネルにバスコントローラを相互接続するように適合されたネットワーク・デバイス・インターフェイスであって、
前記共通デジタルバスを介して前記バスコントローラからメッセージを受信するための受信機と、
前記受信機によって受信されたメッセージに応答して前記関連するデータチャネルにコマンドを供給するための、および、前記関連するデータチャネルからデータを受信するための、デバイスインターフェイスと、
前記共通デジタルバスを介して前記バスコントローラにメッセージを送信するための送信機とを含み、
前記受信機は、クロック信号に前記メッセージが供給されているかどうかを判断するためのクロック検出器を含み、前記クロック検出器が、同期クロック信号に前記受信されたメッセージが供給されていると判断する場合には、前記送信機は、前記同期クロック信号
に従ったメッセージを送信するように、同期モードで前記バスコントローラと同一のビットレートでメッセージを送信し、前記クロック検出器が、受信されたメッセージは付随するどのような同期クロック信号からも独立していると判断する場合には、前記送信機は、非同期モードでメッセージを送信し、
前記バスコントローラは、共通クロックバスを介して同期クロック信号を供給し、前記送信機が前記非同期モードでメッセージを送信するように、前記共通クロックバスが1と0との間で遷移のない状態に前記クロック信号を維持すると前記クロック検出器が判断する、ネットワーク・デバイス・インターフェイス。 - 前記送信機は、前記クロック検出器が同期クロック遷移に前記メッセージが供給されていると判断できない場合に、非同期モードでメッセージを送信する、請求項10に記載のネットワーク・デバイス・インターフェイス。
- 前記受信機は、前記メッセージが前記受信機によって受信されるビットレートを判断するためのビットレート検出器をさらに含み、前記クロック検出器が、前記受信されたメッセージは同期クロック信号に供給されていると判断する場合に、前記送信機は、前記クロック信号と同期させてメッセージを送信し、前記送信機は、前記非同期モードで、前記ビットレート検出器によって判断された前記ビットレートでメッセージを送信する、請求項10に記載のネットワーク・デバイス・インターフェイス。
- 前記受信機は、前記共通デジタルバスを介して、バスコントローラからコマンドおよびアドレスを含むメッセージを受信し、
前記受信機は、前記メッセージが前記関連するデータチャネルにアドレス指定されてい るかどうかを判断するために、前記アドレスを分析するためのアドレスデコーダを含み、
前記アドレスデコーダは、複数のビットを含むマスクを含み、各ビットは、それぞれのグループと関連しており、前記関連するデータチャネルが前記グループのメンバーであることを示す第1の状態と、前記関連するデータチャネルが前記グループの非メンバーであることを示す第2の状態とを有し、前記アドレスデコーダは、グループアドレスを含むメッセージの受信に応答して、前記関連するデータチャネルが、前記マスクの参照によって、前記それぞれのグループのメンバーであるかどうかを判断し、
前記デバイスインターフェイスは、前記受信機によって受信され、かつ、前記関連するデータチャネルにアドレス指定されたと判断されたメッセージに応答して、前記関連するデータチャネルにコマンドを供給し、前記関連するデータチャネルからデータを受信する、請求項10に記載のネットワーク・デバイス・インターフェイス。 - 前記アドレスデコーダは、前記マスクを記憶するための記憶素子を含む、請求項13に記載のネットワーク・デバイス・インターフェイス。
- 前記アドレスデコーダの前記マスクは、前記関連するデータチャネルが多数のグループのメンバーであるように規定する、請求項13に記載のネットワーク・デバイス・インターフェイス。
- 前記アドレスデコーダは、前記関連するデータチャネルが個々にもアドレス指定可能であるように、前記関連するデータチャネルに対する一意の論理アドレスをさらに含む、請求項13に記載のネットワーク・デバイス・インターフェイス。
- 前記ネットワーク・デバイス・インターフェイスに取付けられた各データチャネルに一意の論理アドレスおよびグループマスクを割当てる前に、ネットワーク・デバイス・インターフェイスのすべてが前記バスコントローラによって個々に識別され得るように、製造者によって各ネットワーク・デバイス・インターフェイスに割当てられた識別番号を記憶するための記憶装置をさらに含む、請求項16に記載のネットワーク・デバイス・インターフェイス。
Applications Claiming Priority (3)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US25413600P | 2000-12-08 | 2000-12-08 | |
US09/735,146 US6708239B1 (en) | 2000-12-08 | 2000-12-12 | Network device interface for digitally interfacing data channels to a controller via a network |
PCT/US2001/044144 WO2002047324A2 (en) | 2000-12-08 | 2001-11-05 | Network device interface for digitally interfacing data channels to a controller via a network |
Related Child Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
JP2007113395A Division JP4709800B2 (ja) | 2000-12-08 | 2007-04-23 | ネットワーク経由でデータチャネルをコントローラにデジタル方式でインターフェイスするためのネットワーク・デバイス・インターフェイス |
Publications (2)
Publication Number | Publication Date |
---|---|
JP2004515966A JP2004515966A (ja) | 2004-05-27 |
JP3995594B2 true JP3995594B2 (ja) | 2007-10-24 |
Family
ID=26943848
Family Applications (2)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
JP2002548925A Expired - Lifetime JP3995594B2 (ja) | 2000-12-08 | 2001-11-05 | ネットワーク経由でデータチャネルをコントローラにデジタル方式でインターフェイスするためのネットワーク・デバイス・インターフェイス |
JP2007113395A Expired - Lifetime JP4709800B2 (ja) | 2000-12-08 | 2007-04-23 | ネットワーク経由でデータチャネルをコントローラにデジタル方式でインターフェイスするためのネットワーク・デバイス・インターフェイス |
Family Applications After (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
JP2007113395A Expired - Lifetime JP4709800B2 (ja) | 2000-12-08 | 2007-04-23 | ネットワーク経由でデータチャネルをコントローラにデジタル方式でインターフェイスするためのネットワーク・デバイス・インターフェイス |
Country Status (5)
Country | Link |
---|---|
US (7) | US6708239B1 (ja) |
EP (6) | EP1356629B1 (ja) |
JP (2) | JP3995594B2 (ja) |
AU (1) | AU2002241516A1 (ja) |
WO (1) | WO2002047324A2 (ja) |
Families Citing this family (150)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US8172546B2 (en) | 1998-11-23 | 2012-05-08 | Entegris, Inc. | System and method for correcting for pressure variations using a motor |
US20030048862A1 (en) * | 2001-09-10 | 2003-03-13 | Hsin-Hsien Lee | Automatic calibration & synchronization for digital asynchronous communication |
US7320035B2 (en) * | 2002-03-01 | 2008-01-15 | Sun Microsystems, Inc. | Object mutation determination for incremental state saves |
US6973516B1 (en) * | 2002-05-20 | 2005-12-06 | Intransa, Inc. | Method and apparatus for a controller capable of supporting multiple protocols |
US6931461B2 (en) * | 2002-06-14 | 2005-08-16 | Intel Corporation | Bus optimization based on network device communication |
US8788377B2 (en) * | 2002-10-15 | 2014-07-22 | Ezshield, Inc. | System and method for providing recovery for victims of check fraud |
US7386704B2 (en) | 2002-10-31 | 2008-06-10 | Lockheed Martin Corporation | Pipeline accelerator including pipeline circuits in communication via a bus, and related system and method |
US7174402B2 (en) * | 2003-04-07 | 2007-02-06 | The Boeing Company | Systems, network devices and methods for highly configurable peer-to-peer communications between network devices communicating via a common bus |
US7131024B1 (en) * | 2003-09-24 | 2006-10-31 | Altera Corporation | Multiple transmit data rates in programmable logic device serial interface |
DE10354494B4 (de) * | 2003-11-21 | 2019-04-11 | Siemens Healthcare Gmbh | Verfahren zur Daten- und Signalübertragung zwischen unterschiedlichen Teileinheiten einer medizintechnischen Anlage |
JP4137778B2 (ja) | 2003-12-12 | 2008-08-20 | 三菱電機株式会社 | データ収集システム |
US20050182884A1 (en) * | 2004-01-22 | 2005-08-18 | Hofmann Richard G. | Multiple address two channel bus structure |
US7457834B2 (en) | 2004-07-30 | 2008-11-25 | Searete, Llc | Aggregation and retrieval of network sensor data |
US20050256667A1 (en) * | 2004-05-12 | 2005-11-17 | Searete Llc, A Limited Liability Corporation Of The State Of Delaware | Federating mote-associated log data |
US7941188B2 (en) | 2004-03-31 | 2011-05-10 | The Invention Science Fund I, Llc | Occurrence data detection and storage for generalized sensor networks |
US7389295B2 (en) * | 2004-06-25 | 2008-06-17 | Searete Llc | Using federated mote-associated logs |
US8335814B2 (en) * | 2004-03-31 | 2012-12-18 | The Invention Science Fund I, Llc | Transmission of aggregated mote-associated index data |
US8346846B2 (en) * | 2004-05-12 | 2013-01-01 | The Invention Science Fund I, Llc | Transmission of aggregated mote-associated log data |
US20060064402A1 (en) * | 2004-07-27 | 2006-03-23 | Jung Edward K Y | Using federated mote-associated indexes |
US20060079285A1 (en) * | 2004-03-31 | 2006-04-13 | Jung Edward K Y | Transmission of mote-associated index data |
US8161097B2 (en) * | 2004-03-31 | 2012-04-17 | The Invention Science Fund I, Llc | Aggregating mote-associated index data |
US8275824B2 (en) * | 2004-03-31 | 2012-09-25 | The Invention Science Fund I, Llc | Occurrence data detection and storage for mote networks |
US20060004888A1 (en) * | 2004-05-21 | 2006-01-05 | Searete Llc, A Limited Liability Corporation Of The State Delaware | Using mote-associated logs |
WO2005099233A2 (en) * | 2004-03-31 | 2005-10-20 | Searete Llc | Transmission of mote-associated index data |
US20060062252A1 (en) * | 2004-06-30 | 2006-03-23 | Jung Edward K | Mote appropriate network power reduction techniques |
US20050265388A1 (en) * | 2004-05-12 | 2005-12-01 | Searete Llc, A Limited Liability Corporation Of The State Of Delaware | Aggregating mote-associated log data |
US7599696B2 (en) * | 2004-06-25 | 2009-10-06 | Searete, Llc | Frequency reuse techniques in mote-appropriate networks |
US9062992B2 (en) * | 2004-07-27 | 2015-06-23 | TriPlay Inc. | Using mote-associated indexes |
US7536388B2 (en) * | 2004-03-31 | 2009-05-19 | Searete, Llc | Data storage for distributed sensor networks |
US7929914B2 (en) * | 2004-03-31 | 2011-04-19 | The Invention Science Fund I, Llc | Mote networks using directional antenna techniques |
US20050267960A1 (en) * | 2004-05-12 | 2005-12-01 | Searete Llc, A Limited Liability Corporation Of The State Of Delaware | Mote-associated log creation |
US8200744B2 (en) * | 2004-03-31 | 2012-06-12 | The Invention Science Fund I, Llc | Mote-associated index creation |
US9261383B2 (en) | 2004-07-30 | 2016-02-16 | Triplay, Inc. | Discovery of occurrence-data |
US7725080B2 (en) * | 2004-03-31 | 2010-05-25 | The Invention Science Fund I, Llc | Mote networks having directional antennas |
US20050227686A1 (en) * | 2004-03-31 | 2005-10-13 | Jung Edward K Y | Federating mote-associated index data |
US7487302B2 (en) * | 2004-10-01 | 2009-02-03 | Lockheed Martin Corporation | Service layer architecture for memory access system and method |
US20060095724A1 (en) * | 2004-10-28 | 2006-05-04 | Microsoft Corporation | Message-passing processor |
US7342913B2 (en) * | 2004-11-23 | 2008-03-11 | The Boeing Company | Method for assigning slots in a mobile network |
US8292598B2 (en) | 2004-11-23 | 2012-10-23 | Entegris, Inc. | System and method for a variable home position dispense system |
US7676342B2 (en) * | 2004-12-23 | 2010-03-09 | Asml Netherlands B.V. | Sensor assembly, digital serial bus and protocol, sensor network, and lithographic apparatus and system |
US8041844B2 (en) * | 2004-12-29 | 2011-10-18 | Intel Corporation | Autodetection of a PCI express device operating at a wireless RF mitigation frequency |
US7406555B2 (en) * | 2005-04-29 | 2008-07-29 | The Boeing Company | Systems and methods for multiple input instrumentation buses |
US20060271321A1 (en) * | 2005-05-24 | 2006-11-30 | Visteon Global Technologies, Inc. | Initiating calibration mode of electronic control module |
US7830899B2 (en) * | 2005-05-27 | 2010-11-09 | Agere Systems Inc. | Obtaining channel status in a network-based data transport architecture |
US7904182B2 (en) | 2005-06-08 | 2011-03-08 | Brooks Automation, Inc. | Scalable motion control system |
DE102005033211A1 (de) * | 2005-07-13 | 2007-01-18 | Deutsche Thomson-Brandt Gmbh | Verfahren zur Feststellung der Aktivität eines Gerätes in einem Netzwerk verteilter Stationen sowie Netzwerkstation für die Durchführung des Verfahrens |
US8065441B2 (en) * | 2005-08-19 | 2011-11-22 | Intel Corporation | Method and apparatus for supporting universal serial bus devices in a virtualized environment |
US8753097B2 (en) | 2005-11-21 | 2014-06-17 | Entegris, Inc. | Method and system for high viscosity pump |
WO2007061956A2 (en) | 2005-11-21 | 2007-05-31 | Entegris, Inc. | System and method for a pump with reduced form factor |
US7878765B2 (en) * | 2005-12-02 | 2011-02-01 | Entegris, Inc. | System and method for monitoring operation of a pump |
WO2007067358A2 (en) * | 2005-12-02 | 2007-06-14 | Entegris, Inc. | System and method for pressure compensation in a pump |
US8025486B2 (en) | 2005-12-02 | 2011-09-27 | Entegris, Inc. | System and method for valve sequencing in a pump |
DE602006021614D1 (de) | 2005-12-02 | 2011-06-09 | Entegris Inc | E/a-systeme, verfahren und einrichtungen zur anschaltung einer pumpensteuerung |
US7850431B2 (en) * | 2005-12-02 | 2010-12-14 | Entegris, Inc. | System and method for control of fluid pressure |
US7547049B2 (en) * | 2005-12-02 | 2009-06-16 | Entegris, Inc. | O-ring-less low profile fittings and fitting assemblies |
US8083498B2 (en) | 2005-12-02 | 2011-12-27 | Entegris, Inc. | System and method for position control of a mechanical piston in a pump |
JP5345853B2 (ja) * | 2005-12-05 | 2013-11-20 | インテグリス・インコーポレーテッド | ポンプのための誤差容積システムおよび方法 |
US20070204323A1 (en) * | 2006-02-24 | 2007-08-30 | Rockwell Automation Technologies, Inc. | Auto-detection capabilities for out of the box experience |
US7844762B2 (en) * | 2006-02-24 | 2010-11-30 | Silicon Image, Inc. | Parallel interface bus to communicate video data encoded for serial data links |
TWI402423B (zh) | 2006-02-28 | 2013-07-21 | Entegris Inc | 用於一幫浦操作之系統及方法 |
US7494265B2 (en) * | 2006-03-01 | 2009-02-24 | Entegris, Inc. | System and method for controlled mixing of fluids via temperature |
US7684446B2 (en) * | 2006-03-01 | 2010-03-23 | Entegris, Inc. | System and method for multiplexing setpoints |
WO2007125472A2 (en) * | 2006-04-28 | 2007-11-08 | Nxp B.V. | Data processing apparatus |
US8819326B1 (en) * | 2006-12-12 | 2014-08-26 | Spansion Llc | Host/client system having a scalable serial bus interface |
KR20090004266A (ko) * | 2007-07-06 | 2009-01-12 | 한국전자통신연구원 | 자체 제어 기능을 갖는 기능 모듈 및 이의 동작 제어방법과, 이를 이용한 시스템 |
US8362886B2 (en) * | 2007-09-26 | 2013-01-29 | Omega Patents, L.L.C. | Multi-controller data bus adaptor and associated methods |
US9122797B2 (en) * | 2008-09-30 | 2015-09-01 | Honeywell International Inc. | Deterministic remote interface unit emulator |
JP2010086318A (ja) * | 2008-09-30 | 2010-04-15 | Digital Electronics Corp | デバッグシステム |
US8560125B2 (en) | 2008-10-27 | 2013-10-15 | Lennox Industries | Communication protocol system and method for a distributed-architecture heating, ventilation and air conditioning network |
US8564400B2 (en) | 2008-10-27 | 2013-10-22 | Lennox Industries, Inc. | Communication protocol system and method for a distributed-architecture heating, ventilation and air conditioning network |
US8463442B2 (en) | 2008-10-27 | 2013-06-11 | Lennox Industries, Inc. | Alarm and diagnostics system and method for a distributed architecture heating, ventilation and air conditioning network |
US8798796B2 (en) | 2008-10-27 | 2014-08-05 | Lennox Industries Inc. | General control techniques in a heating, ventilation and air conditioning network |
US8543243B2 (en) | 2008-10-27 | 2013-09-24 | Lennox Industries, Inc. | System and method of use for a user interface dashboard of a heating, ventilation and air conditioning network |
US8655490B2 (en) | 2008-10-27 | 2014-02-18 | Lennox Industries, Inc. | System and method of use for a user interface dashboard of a heating, ventilation and air conditioning network |
US8874815B2 (en) | 2008-10-27 | 2014-10-28 | Lennox Industries, Inc. | Communication protocol system and method for a distributed architecture heating, ventilation and air conditioning network |
US8762666B2 (en) | 2008-10-27 | 2014-06-24 | Lennox Industries, Inc. | Backup and restoration of operation control data in a heating, ventilation and air conditioning network |
US8725298B2 (en) | 2008-10-27 | 2014-05-13 | Lennox Industries, Inc. | Alarm and diagnostics system and method for a distributed architecture heating, ventilation and conditioning network |
US8239066B2 (en) | 2008-10-27 | 2012-08-07 | Lennox Industries Inc. | System and method of use for a user interface dashboard of a heating, ventilation and air conditioning network |
US8802981B2 (en) | 2008-10-27 | 2014-08-12 | Lennox Industries Inc. | Flush wall mount thermostat and in-set mounting plate for a heating, ventilation and air conditioning system |
US8994539B2 (en) | 2008-10-27 | 2015-03-31 | Lennox Industries, Inc. | Alarm and diagnostics system and method for a distributed-architecture heating, ventilation and air conditioning network |
US8977794B2 (en) | 2008-10-27 | 2015-03-10 | Lennox Industries, Inc. | Communication protocol system and method for a distributed-architecture heating, ventilation and air conditioning network |
US9377768B2 (en) | 2008-10-27 | 2016-06-28 | Lennox Industries Inc. | Memory recovery scheme and data structure in a heating, ventilation and air conditioning network |
US8352081B2 (en) | 2008-10-27 | 2013-01-08 | Lennox Industries Inc. | Communication protocol system and method for a distributed-architecture heating, ventilation and air conditioning network |
US8655491B2 (en) | 2008-10-27 | 2014-02-18 | Lennox Industries Inc. | Alarm and diagnostics system and method for a distributed architecture heating, ventilation and air conditioning network |
US8255086B2 (en) | 2008-10-27 | 2012-08-28 | Lennox Industries Inc. | System recovery in a heating, ventilation and air conditioning network |
US8744629B2 (en) | 2008-10-27 | 2014-06-03 | Lennox Industries Inc. | System and method of use for a user interface dashboard of a heating, ventilation and air conditioning network |
US9152155B2 (en) | 2008-10-27 | 2015-10-06 | Lennox Industries Inc. | Device abstraction system and method for a distributed-architecture heating, ventilation and air conditioning system |
US8694164B2 (en) | 2008-10-27 | 2014-04-08 | Lennox Industries, Inc. | Interactive user guidance interface for a heating, ventilation and air conditioning system |
US8661165B2 (en) | 2008-10-27 | 2014-02-25 | Lennox Industries, Inc. | Device abstraction system and method for a distributed architecture heating, ventilation and air conditioning system |
US9268345B2 (en) | 2008-10-27 | 2016-02-23 | Lennox Industries Inc. | System and method of use for a user interface dashboard of a heating, ventilation and air conditioning network |
US8600558B2 (en) | 2008-10-27 | 2013-12-03 | Lennox Industries Inc. | System recovery in a heating, ventilation and air conditioning network |
US8615326B2 (en) | 2008-10-27 | 2013-12-24 | Lennox Industries Inc. | System and method of use for a user interface dashboard of a heating, ventilation and air conditioning network |
US9261888B2 (en) | 2008-10-27 | 2016-02-16 | Lennox Industries Inc. | System and method of use for a user interface dashboard of a heating, ventilation and air conditioning network |
US8892797B2 (en) | 2008-10-27 | 2014-11-18 | Lennox Industries Inc. | Communication protocol system and method for a distributed-architecture heating, ventilation and air conditioning network |
US8548630B2 (en) | 2008-10-27 | 2013-10-01 | Lennox Industries, Inc. | Alarm and diagnostics system and method for a distributed-architecture heating, ventilation and air conditioning network |
US9432208B2 (en) | 2008-10-27 | 2016-08-30 | Lennox Industries Inc. | Device abstraction system and method for a distributed architecture heating, ventilation and air conditioning system |
US8452456B2 (en) | 2008-10-27 | 2013-05-28 | Lennox Industries Inc. | System and method of use for a user interface dashboard of a heating, ventilation and air conditioning network |
US9678486B2 (en) | 2008-10-27 | 2017-06-13 | Lennox Industries Inc. | Device abstraction system and method for a distributed-architecture heating, ventilation and air conditioning system |
US8295981B2 (en) | 2008-10-27 | 2012-10-23 | Lennox Industries Inc. | Device commissioning in a heating, ventilation and air conditioning network |
US9325517B2 (en) | 2008-10-27 | 2016-04-26 | Lennox Industries Inc. | Device abstraction system and method for a distributed-architecture heating, ventilation and air conditioning system |
US8352080B2 (en) | 2008-10-27 | 2013-01-08 | Lennox Industries Inc. | Communication protocol system and method for a distributed-architecture heating, ventilation and air conditioning network |
US8774210B2 (en) | 2008-10-27 | 2014-07-08 | Lennox Industries, Inc. | Communication protocol system and method for a distributed-architecture heating, ventilation and air conditioning network |
US8463443B2 (en) | 2008-10-27 | 2013-06-11 | Lennox Industries, Inc. | Memory recovery scheme and data structure in a heating, ventilation and air conditioning network |
US9632490B2 (en) | 2008-10-27 | 2017-04-25 | Lennox Industries Inc. | System and method for zoning a distributed architecture heating, ventilation and air conditioning network |
US8600559B2 (en) | 2008-10-27 | 2013-12-03 | Lennox Industries Inc. | Method of controlling equipment in a heating, ventilation and air conditioning network |
US8437878B2 (en) | 2008-10-27 | 2013-05-07 | Lennox Industries Inc. | Alarm and diagnostics system and method for a distributed architecture heating, ventilation and air conditioning network |
US8855825B2 (en) | 2008-10-27 | 2014-10-07 | Lennox Industries Inc. | Device abstraction system and method for a distributed-architecture heating, ventilation and air conditioning system |
US8788100B2 (en) | 2008-10-27 | 2014-07-22 | Lennox Industries Inc. | System and method for zoning a distributed-architecture heating, ventilation and air conditioning network |
US8442693B2 (en) | 2008-10-27 | 2013-05-14 | Lennox Industries, Inc. | System and method of use for a user interface dashboard of a heating, ventilation and air conditioning network |
US8433446B2 (en) | 2008-10-27 | 2013-04-30 | Lennox Industries, Inc. | Alarm and diagnostics system and method for a distributed-architecture heating, ventilation and air conditioning network |
US8452906B2 (en) | 2008-10-27 | 2013-05-28 | Lennox Industries, Inc. | Communication protocol system and method for a distributed-architecture heating, ventilation and air conditioning network |
US9651925B2 (en) | 2008-10-27 | 2017-05-16 | Lennox Industries Inc. | System and method for zoning a distributed-architecture heating, ventilation and air conditioning network |
US8437877B2 (en) | 2008-10-27 | 2013-05-07 | Lennox Industries Inc. | System recovery in a heating, ventilation and air conditioning network |
DE102008057445B4 (de) * | 2008-11-14 | 2020-10-08 | Phoenix Contact Gmbh & Co. Kg | Feldbussystem mit Spread-Spektrum |
US8862685B2 (en) | 2008-11-21 | 2014-10-14 | Continental Teves Ag & Co. Ohg | Data transmission protocol for synchronization communication between two communication devices |
US8503484B2 (en) * | 2009-01-19 | 2013-08-06 | Honeywell International Inc. | System and method for a cross channel data link |
US8275918B2 (en) * | 2009-04-01 | 2012-09-25 | Setra Systems, Inc. | Environmental condition monitor for alternative communication protocols |
JP5363379B2 (ja) * | 2009-05-20 | 2013-12-11 | ルネサスエレクトロニクス株式会社 | 通信システム |
US8903572B1 (en) | 2009-08-11 | 2014-12-02 | The Boeing Company | Aircraft landing evaluation system |
USD648642S1 (en) | 2009-10-21 | 2011-11-15 | Lennox Industries Inc. | Thin cover plate for an electronic system controller |
USD648641S1 (en) | 2009-10-21 | 2011-11-15 | Lennox Industries Inc. | Thin cover plate for an electronic system controller |
KR101566883B1 (ko) * | 2009-12-29 | 2015-11-09 | 삼성전자주식회사 | 콘텐츠 명 기반의 네트워크 장치 및 데이터 요청 방법 |
US8260444B2 (en) | 2010-02-17 | 2012-09-04 | Lennox Industries Inc. | Auxiliary controller of a HVAC system |
CN101977244A (zh) * | 2010-09-21 | 2011-02-16 | 华为终端有限公司 | 一种控制方法、装置和系统 |
DE102010041368A1 (de) * | 2010-09-24 | 2012-04-19 | Robert Bosch Gmbh | Verfahren und Teilnehmerstation zum optimierten Übertragen von Daten zwischen Teilnehmerstationen eines Bussystems |
US20120143438A1 (en) * | 2010-12-01 | 2012-06-07 | Nissan North America, Inc. | Fiber optic vehicle communication system |
GB201114715D0 (en) * | 2011-08-25 | 2011-10-12 | Ultrasoc Technologies Ltd | A data processing apparatus and related methods of debugging processing circuitry |
US8826081B2 (en) * | 2011-08-25 | 2014-09-02 | Ultrasoc Technologies, Ltd. | Data processing apparatus and related methods of debugging processing circuitry |
FR2996019B1 (fr) * | 2012-09-21 | 2014-10-31 | Thales Sa | Structure de controleur d'echanges de donnees et de communications generique et multi roles |
US9037693B2 (en) | 2013-01-03 | 2015-05-19 | The Boeing Company | Locating and addressing communication devices |
US10089224B2 (en) | 2013-03-15 | 2018-10-02 | The Boeing Company | Write caching using volatile shadow memory |
US9904556B1 (en) | 2013-03-15 | 2018-02-27 | The Boeing Company | Executing a boot sequence including movement of data through a buffer memory |
US9811455B2 (en) * | 2013-03-15 | 2017-11-07 | The Boeing Company | Accessing different types of memory by respective distinct command with different timing requirements |
US9733638B2 (en) | 2013-04-05 | 2017-08-15 | Symbotic, LLC | Automated storage and retrieval system and control system thereof |
US9989947B2 (en) * | 2013-08-20 | 2018-06-05 | Infineon Technologies Ag | Driver circuit for driving electromagnetic actuators |
US9331868B2 (en) | 2013-10-15 | 2016-05-03 | At&T Intellectual Property I, L.P. | Method of bus virtualization in computing machine intercommunications |
CN105960629B (zh) * | 2013-12-30 | 2020-11-24 | 施耐德电气It公司 | 在can网络中自动选择波特率的系统和方法 |
US9794335B2 (en) | 2014-06-02 | 2017-10-17 | The Boeing Company | Computer system synchronization |
JP6054927B2 (ja) * | 2014-09-22 | 2016-12-27 | ファナック株式会社 | 複数の通信回線を利用するdnc運転機能を備えた数値制御装置 |
KR101573637B1 (ko) * | 2014-11-03 | 2015-12-01 | 현대자동차주식회사 | 데이터량 증대로 통신속도 개선을 위한 can 통신 방법 및 데이터 프레임 구조 |
KR101645560B1 (ko) * | 2015-02-16 | 2016-08-04 | 두산중공업 주식회사 | 데이터 처리 장치 |
EP3068112B1 (en) * | 2015-03-11 | 2018-05-23 | Advanced Digital Broadcast S.A. | System and method for mac address acquisition |
CN104702470B (zh) * | 2015-03-31 | 2017-11-14 | 南京埃斯顿自动控制技术有限公司 | 基于fpga的波特率在线检测方法 |
US10184860B2 (en) | 2016-04-08 | 2019-01-22 | Infineon Technologies Ag | Control system for power train control |
CN112512911A (zh) | 2018-06-01 | 2021-03-16 | 斯蒂尔赫德液化天然气有限公司 | 液化设备、方法和系统 |
FR3090530B1 (fr) * | 2018-12-20 | 2021-04-23 | Commissariat Energie Atomique | Architecture électronique pour système embarqué |
US11379571B2 (en) * | 2019-07-12 | 2022-07-05 | Hewlett Packard Enterprise Development Lp | Presence terminal-based side channel communications |
CN110413558A (zh) * | 2019-07-15 | 2019-11-05 | 广芯微电子(广州)股份有限公司 | 一种实现低功耗串口模块动态分频方法 |
US11132268B2 (en) | 2019-10-21 | 2021-09-28 | The Boeing Company | System and method for synchronizing communications between a plurality of processors |
US11418422B1 (en) * | 2021-02-08 | 2022-08-16 | Mellanox Technologies, Ltd. | Received-signal rate detection |
Family Cites Families (85)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US3909724A (en) * | 1973-06-26 | 1975-09-30 | Addressograph Multigraph | Start bit detector and data strober for asynchronous receiver |
GB1502184A (en) * | 1974-07-05 | 1978-02-22 | Sperry Rand Corp | Automatic flight control systems |
DE2615306C2 (de) * | 1976-04-08 | 1982-06-03 | Vereinigte Flugtechnische Werke Gmbh, 2800 Bremen | Meßdatenerfassungs- und Verarbeitungsanlage |
US4241416A (en) | 1977-07-01 | 1980-12-23 | Systron-Donner Corporation | Monitoring apparatus for processor controlled equipment |
US4124778A (en) * | 1977-11-02 | 1978-11-07 | Minnesota Mining And Manufacturing Company | Digital frame synchronizing circuit |
US4479179A (en) | 1979-07-30 | 1984-10-23 | International Business Machines Corporation | Synchronous cycle steal mechanism for transferring data between a processor storage unit and a separate data handling unit |
US4304001A (en) | 1980-01-24 | 1981-12-01 | Forney Engineering Company | Industrial control system with interconnected remotely located computer control units |
US4449202A (en) * | 1981-12-04 | 1984-05-15 | Ncr Corporation | Full duplex integrated circuit communication controller |
US4449119A (en) * | 1981-12-14 | 1984-05-15 | International Business Machines Corporation | Self-clocking serial decoder |
US4964040A (en) | 1983-01-03 | 1990-10-16 | United States Of America As Represented By The Secretary Of The Navy | Computer hardware executive |
US4688168A (en) | 1984-08-23 | 1987-08-18 | Picker International Inc. | High speed data transfer method and apparatus |
US5008877A (en) * | 1986-11-25 | 1991-04-16 | Raychem Corp. | Optical signal recovery for distribution communication system |
US4785469A (en) * | 1987-02-12 | 1988-11-15 | Advanced Micro Devices, Inc. | Processor to peripheral interface for asynchronous or synchronous applications |
DE3730468A1 (de) | 1987-09-08 | 1989-03-16 | Bergmann Kabelwerke Ag | Bordnetz fuer kraftfahrzeuge und verfahren zum betrieb des bordnetzes |
US4918690A (en) * | 1987-11-10 | 1990-04-17 | Echelon Systems Corp. | Network and intelligent cell for providing sensing, bidirectional communications and control |
US5113498A (en) * | 1987-11-10 | 1992-05-12 | Echelon Corporation | Input/output section for an intelligent cell which provides sensing, bidirectional communications and control |
US4969147A (en) | 1987-11-10 | 1990-11-06 | Echelon Systems Corporation | Network and intelligent cell for providing sensing, bidirectional communications and control |
US5020020A (en) * | 1989-04-07 | 1991-05-28 | Digital Equipment Corporation | Computer interconnect system with transmit-abort function |
US4942147A (en) * | 1989-05-08 | 1990-07-17 | Union Carbide Chemicals And Plastics Company, Inc. | Catalyst system containing an autoacceleration inhibitor |
JP2702773B2 (ja) * | 1989-05-10 | 1998-01-26 | 松下電器産業株式会社 | データモニタ装置 |
US4996684A (en) | 1989-07-06 | 1991-02-26 | Northern Telecom Limited | Electronic systems and effective reduction of electromagnetic interference energy propagation from electronic systems |
AU7305491A (en) * | 1990-01-29 | 1991-08-21 | Teraplex, Inc. | Architecture for minimal instruction set computing system |
ATE121208T1 (de) * | 1990-01-30 | 1995-04-15 | Johnson Service Co | Vernetztes betriebsmittelverwaltungssystem. |
GB9006661D0 (en) | 1990-03-24 | 1990-05-23 | Reflex Manufacturing Systems L | Network-field interface for manufacturing systems |
US5138709A (en) | 1990-04-11 | 1992-08-11 | Motorola, Inc. | Spurious interrupt monitor |
US5201056A (en) * | 1990-05-02 | 1993-04-06 | Motorola, Inc. | RISC microprocessor architecture with multi-bit tag extended instructions for selectively attaching tag from either instruction or input data to arithmetic operation output |
US5223610A (en) * | 1990-05-18 | 1993-06-29 | The Scripps Research Institute | Cholera toxin gene regulated by growth hormone promoter |
US5367678A (en) | 1990-12-06 | 1994-11-22 | The Regents Of The University Of California | Multiprocessor system having statically determining resource allocation schedule at compile time and the using of static schedule with processor signals to control the execution time dynamically |
US5426741A (en) | 1991-02-20 | 1995-06-20 | Digital Equipment Corporation | Bus event monitor |
JPH04305754A (ja) * | 1991-04-02 | 1992-10-28 | Furukawa Electric Co Ltd:The | 多重伝送方式 |
US5274783A (en) | 1991-06-28 | 1993-12-28 | Digital Equipment Corporation | SCSI interface employing bus extender and auxiliary bus |
US5625821A (en) | 1991-08-12 | 1997-04-29 | International Business Machines Corporation | Asynchronous or synchronous operation of event signaller by event management services in a computer system |
US5223806A (en) | 1991-08-23 | 1993-06-29 | Digital Equipment Corporation | Method and apparatus for reducing electromagnetic interference and emission associated with computer network interfaces |
US5291614A (en) | 1991-09-03 | 1994-03-01 | International Business Machines Corporation | Real-time, concurrent, multifunction digital signal processor subsystem for personal computers |
US5469545A (en) * | 1991-10-03 | 1995-11-21 | Compaq Computer Corp. | Expandable communication system with data flow control |
US5251208A (en) | 1991-12-19 | 1993-10-05 | At&T Bell Laboratories | Digital signal processor synchronous network |
DE69328320T2 (de) | 1992-01-09 | 2000-11-30 | Cabletron Systems Inc | Vorrichtung und Verfahren zur Datenübertragung zu und von einem Wirtrechnersystem |
US5390351A (en) * | 1992-03-06 | 1995-02-14 | Pitney Bowes Inc. | System for communicating with plural nodes in predetermined intervals depended on integers assigned and changed based upon configuration thereof |
US5627858A (en) * | 1992-07-20 | 1997-05-06 | Telefonaktiebolaget L M Ericsson | Multi-channel autobauding circuit |
TW276312B (ja) | 1992-10-20 | 1996-05-21 | Cirrlis Logic Inc | |
US5437060A (en) | 1993-06-01 | 1995-07-25 | Itronix Corporation | Apparatus and method for reducing interference in a communications system |
US5445128A (en) | 1993-08-27 | 1995-08-29 | Detroit Diesel Corporation | Method for engine control |
TW311190B (ja) * | 1994-01-19 | 1997-07-21 | Tokyo Electron Co Ltd | |
GB2288954B (en) * | 1994-04-15 | 1998-10-14 | Vlsi Technology Inc | Method and apparatus for providing programmable serial communications |
US5654983A (en) * | 1994-06-10 | 1997-08-05 | Hayes Microcomputer Products, Inc. | Method and apparatus of operating data communications equipment in command mode and autobauding |
US5557634A (en) | 1994-10-14 | 1996-09-17 | International Business Machines Corporation | Multiprotocol directed infrared communication controller |
US5623610A (en) | 1994-10-31 | 1997-04-22 | Intel Corporation | System for assigning geographical addresses in a hierarchical serial bus by enabling upstream port and selectively enabling disabled ports at power on/reset |
US5742847A (en) | 1994-10-31 | 1998-04-21 | Intel Corporation | M&A for dynamically generating and maintaining frame based polling schedules for polling isochronous and asynchronous functions that guaranty latencies and bandwidths to the isochronous functions |
DE19581234B4 (de) | 1994-10-31 | 2008-03-20 | Intel Corp., Santa Clara | Bussteuereinrichtung und Verfahren für eine hierarchische serielle Busanordnung unter Verwendung von Kommunikationspaketen |
US5615404A (en) | 1994-10-31 | 1997-03-25 | Intel Corporation | System having independently addressable bus interfaces coupled to serially connected multi-ported signal distributors generating and maintaining frame based polling schedule favoring isochronous peripherals |
US5737356A (en) | 1995-03-31 | 1998-04-07 | General Electric Company | Spectral spreading apparatus for reducing electromagnetic radiation from a transmission line used for high data rate communication in a computerized tomography system |
US5708817A (en) | 1995-05-31 | 1998-01-13 | Apple Computer, Inc. | Programmable delay of an interrupt |
US5734329A (en) * | 1995-07-13 | 1998-03-31 | Dell Usa L.P. | Method and apparatus for superimposing self-clocking multifunctional communications on a static digital signal line |
KR0146762B1 (ko) | 1995-07-24 | 1998-08-17 | 양승택 | 병렬 공통 버스형 고속 패킷 교환 시스템에 중재 교환 장치 및 그 방법 |
FR2737826B1 (fr) * | 1995-08-08 | 1997-09-12 | Sextant Avionique | Procede de communication sur un bus a cohabitation de debits differents |
KR0147471B1 (ko) * | 1995-11-24 | 1998-08-17 | 문정환 | 데이터 전송속도 감지기능을 가진 이서네트 |
JP3647955B2 (ja) | 1996-01-23 | 2005-05-18 | 三菱電機株式会社 | 操作ボード、リモートi/o通信制御方法 |
JPH09251437A (ja) | 1996-03-18 | 1997-09-22 | Toshiba Corp | 計算機装置及び連続データサーバ装置 |
US5815516A (en) | 1996-04-05 | 1998-09-29 | International Business Machines Corporation | Method and apparatus for producing transmission control protocol checksums using internet protocol fragmentation |
US5801602A (en) | 1996-04-30 | 1998-09-01 | 3Com Corporation | Isolation and signal filter transformer |
JP3117000B2 (ja) * | 1997-02-21 | 2000-12-11 | 株式会社デンソー | 通信システムおよびそれに使用される電子制御装置 |
US6013108A (en) * | 1997-03-18 | 2000-01-11 | Endevco Corporation | Intelligent sensor system with network bus |
JP3977484B2 (ja) | 1997-05-08 | 2007-09-19 | 矢崎総業株式会社 | 状態情報の管理方法及び通信システム |
US5982837A (en) * | 1997-06-16 | 1999-11-09 | Lsi Logic Corporation | Automatic baud rate detector |
US6904480B1 (en) | 1997-12-17 | 2005-06-07 | Intel Corporation | Testing a bus using bus specific instructions |
US6452938B1 (en) | 1998-02-26 | 2002-09-17 | 3Com Corporation | System and method to reduce electromagnetic interference emissions in a network interface |
US6134676A (en) | 1998-04-30 | 2000-10-17 | International Business Machines Corporation | Programmable hardware event monitoring method |
US6201996B1 (en) | 1998-05-29 | 2001-03-13 | Control Technology Corporationa | Object-oriented programmable industrial controller with distributed interface architecture |
US6724772B1 (en) | 1998-09-04 | 2004-04-20 | Advanced Micro Devices, Inc. | System-on-a-chip with variable bandwidth |
US6195724B1 (en) | 1998-11-16 | 2001-02-27 | Infineon Technologies Ag | Methods and apparatus for prioritization of access to external devices |
US6163586A (en) * | 1998-12-01 | 2000-12-19 | Philips Electronics North America Corp. | Autobaud/autoecho method |
JP2000231403A (ja) * | 1999-02-09 | 2000-08-22 | Keyence Corp | リモート入出力システム及びリモート入出力システムの子機 |
US6134485A (en) | 1999-02-18 | 2000-10-17 | The Boeing Company | System and method for measuring physical parameters using an integrated multisensor system |
DE19911464A1 (de) * | 1999-03-15 | 2000-09-28 | Siemens Ag | Verfahren und Anordnung zur automatischen Gewinnung von Taktsignalen zur Abtastung von Datensignalen unterschiedlicher Datenraten mit Hilfe eines Phasenregelkreises |
JP3366277B2 (ja) * | 1999-03-25 | 2003-01-14 | 日本電気株式会社 | Atコマンド受信回路 |
EP1188285B1 (en) | 1999-04-13 | 2012-06-13 | Broadcom Corporation | Gateway with voice |
US6356809B1 (en) * | 1999-06-11 | 2002-03-12 | Cbi Systems Corporation | Electro-statically shielded processing module |
US6205509B1 (en) | 1999-07-15 | 2001-03-20 | 3Com Corporation | Method for improving interrupt response time |
US6556817B1 (en) | 1999-12-13 | 2003-04-29 | Motorola, Inc. | Method and apparatus for selectively communicating in a wireless communication system based on varying time incremental costs of communication |
US6658515B1 (en) | 2000-01-25 | 2003-12-02 | Dell Usa, L.P. | Background execution of universal serial bus transactions |
US6273771B1 (en) | 2000-03-17 | 2001-08-14 | Brunswick Corporation | Control system for a marine vessel |
US6574515B1 (en) * | 2000-05-12 | 2003-06-03 | Rosemount Inc. | Two-wire field-mounted process device |
US6879820B2 (en) | 2000-07-12 | 2005-04-12 | Telefonaktiebolaget Lm Ericsson (Publ) | Charging in communication networks having split control planes and user planes |
US6674725B2 (en) | 2001-03-05 | 2004-01-06 | Qwest Communications International, Inc. | Method and system for dynamic service classification and integrated service control |
CN1679367A (zh) | 2003-06-27 | 2005-10-05 | 三菱电机株式会社 | 移动通信系统、移动机和网络高端装置 |
-
2000
- 2000-12-12 US US09/735,146 patent/US6708239B1/en not_active Expired - Lifetime
-
2001
- 2001-11-05 JP JP2002548925A patent/JP3995594B2/ja not_active Expired - Lifetime
- 2001-11-05 EP EP01988185.3A patent/EP1356629B1/en not_active Expired - Lifetime
- 2001-11-05 EP EP10186254.8A patent/EP2317411B1/en not_active Expired - Lifetime
- 2001-11-05 EP EP12178641.2A patent/EP2544060B1/en not_active Expired - Lifetime
- 2001-11-05 EP EP20120178794 patent/EP2544062A3/en not_active Ceased
- 2001-11-05 AU AU2002241516A patent/AU2002241516A1/en not_active Abandoned
- 2001-11-05 EP EP12178821A patent/EP2544063A3/en not_active Ceased
- 2001-11-05 EP EP12178685.9A patent/EP2544061B1/en not_active Expired - Lifetime
- 2001-11-05 WO PCT/US2001/044144 patent/WO2002047324A2/en active Application Filing
-
2003
- 2003-12-03 US US10/726,918 patent/US7277970B2/en not_active Expired - Lifetime
- 2003-12-04 US US10/728,349 patent/US7058737B2/en not_active Expired - Lifetime
- 2003-12-04 US US10/727,414 patent/US7096285B2/en not_active Expired - Lifetime
- 2003-12-05 US US10/729,560 patent/US7099965B2/en not_active Expired - Lifetime
- 2003-12-06 US US10/728,664 patent/US6938106B2/en not_active Expired - Lifetime
-
2007
- 2007-04-23 JP JP2007113395A patent/JP4709800B2/ja not_active Expired - Lifetime
- 2007-09-10 US US11/852,706 patent/US7552256B2/en not_active Expired - Lifetime
Also Published As
Similar Documents
Publication | Publication Date | Title |
---|---|---|
JP3995594B2 (ja) | ネットワーク経由でデータチャネルをコントローラにデジタル方式でインターフェイスするためのネットワーク・デバイス・インターフェイス | |
JP2004516698A (ja) | 共通バスを介して遠隔装置をデジタル制御するためのネットワークコントローラ | |
US7689687B2 (en) | Communication controller with automatic time stamping | |
US8417856B1 (en) | High speed sensor data transfer interface | |
EP1679610B1 (en) | System and methods for establishing peer-to-peer communications between network devices communicating via a common bus | |
JP2004312716A (ja) | 共通のバスを介して通信するネットワーク装置間におけるピア・トゥ・ピア通信のためのシステム、方法およびネットワーク装置 | |
US6922790B2 (en) | Three wire communication protocol | |
EP1892890A2 (en) | Network controller for digitally controlling remote devices via a common bus | |
US6570666B1 (en) | Printer detecting data precisely in response to change in data transmission speed | |
CN118089925A (zh) | 一种用于高速振动数据的采集系统及方法 | |
JPH11177589A (ja) | データ転送装置およびデータ転送装置のデータ処理方法およびコンピュータが読み出し可能なプログラムを格納した記憶媒体 | |
JP2001309460A (ja) | デジタルデータの伝送方法 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
A621 | Written request for application examination |
Free format text: JAPANESE INTERMEDIATE CODE: A621 Effective date: 20040831 |
|
A131 | Notification of reasons for refusal |
Free format text: JAPANESE INTERMEDIATE CODE: A131 Effective date: 20070123 |
|
A521 | Written amendment |
Free format text: JAPANESE INTERMEDIATE CODE: A523 Effective date: 20070423 |
|
TRDD | Decision of grant or rejection written | ||
A01 | Written decision to grant a patent or to grant a registration (utility model) |
Free format text: JAPANESE INTERMEDIATE CODE: A01 Effective date: 20070703 |
|
A61 | First payment of annual fees (during grant procedure) |
Free format text: JAPANESE INTERMEDIATE CODE: A61 Effective date: 20070731 |
|
FPAY | Renewal fee payment (event date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20100810 Year of fee payment: 3 |
|
R150 | Certificate of patent or registration of utility model |
Ref document number: 3995594 Country of ref document: JP Free format text: JAPANESE INTERMEDIATE CODE: R150 Free format text: JAPANESE INTERMEDIATE CODE: R150 |
|
FPAY | Renewal fee payment (event date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20100810 Year of fee payment: 3 |
|
FPAY | Renewal fee payment (event date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20110810 Year of fee payment: 4 |
|
R250 | Receipt of annual fees |
Free format text: JAPANESE INTERMEDIATE CODE: R250 |
|
FPAY | Renewal fee payment (event date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20110810 Year of fee payment: 4 |
|
FPAY | Renewal fee payment (event date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20120810 Year of fee payment: 5 |
|
R250 | Receipt of annual fees |
Free format text: JAPANESE INTERMEDIATE CODE: R250 |
|
FPAY | Renewal fee payment (event date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20130810 Year of fee payment: 6 |
|
R250 | Receipt of annual fees |
Free format text: JAPANESE INTERMEDIATE CODE: R250 |
|
R250 | Receipt of annual fees |
Free format text: JAPANESE INTERMEDIATE CODE: R250 |
|
R250 | Receipt of annual fees |
Free format text: JAPANESE INTERMEDIATE CODE: R250 |
|
R250 | Receipt of annual fees |
Free format text: JAPANESE INTERMEDIATE CODE: R250 |
|
R250 | Receipt of annual fees |
Free format text: JAPANESE INTERMEDIATE CODE: R250 |
|
R250 | Receipt of annual fees |
Free format text: JAPANESE INTERMEDIATE CODE: R250 |
|
R250 | Receipt of annual fees |
Free format text: JAPANESE INTERMEDIATE CODE: R250 |
|
R250 | Receipt of annual fees |
Free format text: JAPANESE INTERMEDIATE CODE: R250 |
|
R250 | Receipt of annual fees |
Free format text: JAPANESE INTERMEDIATE CODE: R250 |
|
R250 | Receipt of annual fees |
Free format text: JAPANESE INTERMEDIATE CODE: R250 |
|
EXPY | Cancellation because of completion of term |