JP2007174646A - 同期データ通信 - Google Patents

同期データ通信 Download PDF

Info

Publication number
JP2007174646A
JP2007174646A JP2006337855A JP2006337855A JP2007174646A JP 2007174646 A JP2007174646 A JP 2007174646A JP 2006337855 A JP2006337855 A JP 2006337855A JP 2006337855 A JP2006337855 A JP 2006337855A JP 2007174646 A JP2007174646 A JP 2007174646A
Authority
JP
Japan
Prior art keywords
data packet
node
data
packet
transmission
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.)
Withdrawn
Application number
JP2006337855A
Other languages
English (en)
Inventor
Michael B Druke
ビー. ドルケ マイケル
Christopher J Jacques
ジェイ. ジェイクス クリストファー
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Intuitive Surgical Inc
Original Assignee
Intuitive Surgical Inc
Priority date (The priority date 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 date listed.)
Filing date
Publication date
Application filed by Intuitive Surgical Inc filed Critical Intuitive Surgical Inc
Publication of JP2007174646A publication Critical patent/JP2007174646A/ja
Withdrawn legal-status Critical Current

Links

Images

Landscapes

  • Detection And Prevention Of Errors In Transmission (AREA)
  • Small-Scale Networks (AREA)
  • Communication Control (AREA)
  • Data Exchanges In Wide-Area Networks (AREA)

Abstract

【課題】優れた同期化を実現するパケット通信を提供すること。
【解決手段】本発明により提供されるパケット通信方法は、第1のノードから第2のノードに第1のデータパケットを伝送することと、第1のデータパケットの伝送後に、第1のノードから第2のノードに第2のデータパケットを伝送することと、第1のノードにおいて、第2のノードから伝送される第3のデータパケットを受信することとを含む。第1のデータパケットは、第1のノードからの非充填データを含む第1のデータフィールドを含んでいる。第2のデータパケットの伝送は、第1のデータパケットに対応する任意の受信確認情報が第2のノードから受信される前に開始される。第3のデータパケットは、第1のデータパケットが第2のノードによって正しく受信されたか否かを示す受信確認情報を含んでいる。
【選択図】図2

Description

本出願は、2005年12月22日に出願された米国仮特許出願シリアル番号第60/753,991号の利益を主張し、その全体の内容は、参照のため、本明細書に援用される。
(背景)
本開示は、情報システムに関する。
いくつかのアプリケーションは、通信のために、高帯域要求、ならびに、厳しい同期化、遅延、および信頼性の要求を有している。例えば、ロボット補助式手術は、制御信号とフィードバック信号とをリアルタイムに伝送するために、高帯域を要求する。外科医の動きとロボットの動きとの間には、理想的にはできる限り小さな遅延が存在すべきなので、そのようなアプリケーションの同期化および遅延の要求は、厳しいものとなる。データ伝送のエラーは患者を傷付け得るため、これらのアプリケーションにおける通信は、信頼性が高くなければなければならない。
ロボット補助式手術に用いられる従来のある通信システムは、数百の経路(例えば、ワイヤ)を用いることにより、外科医用の制御コンソールをロボットアームに接続する。しかしながら、数百の経路を用いることは、システムの設定とメンテナンスとを煩雑にし、すべての経路をルーティングするための実質的な空間を要求する。
従来の通信規格は、いくつかのエリアではまずまずの性能を提供するが、他のエリアでは十分な性能を提供しない。例えば、IEEE−1394インターフェース規格は、同期、シリアル、およびポイント・トゥ・ポイントの通信を提供する。IEEE−1394チャネルは、認可された帯域幅を有するが、約125マイクロ秒の範囲内までの同期化を提供し得るに過ぎない。そのような性能は、より厳しい同期化を要求するいくつかのアプリケーションに対しては、十分なものとはなり得ない。
(要約)
一局面において、第1のノードから第2のノードに第1のデータパケットを伝送することを含む方法およびプログラム製品が提供される。第1のデータパケットは、第1のノードからの非充填データを含むデータフィールドを含む。第1のデータパケットの伝送後に、第1のノードから第2のノードに第2のデータパケットが伝送される。第2のデータパケットの伝送は、第1のデータパケットに対応する任意の受信確認情報が第2のノードから受信される前に開始する。第2のノードから伝送された第3のデータパケットは、第1のノードにおいて受信される。第3のデータパケットは、第1のデータパケットが第2のノードによって正しく受信されたか否かを示す受信確認情報を含んでいる。第1のデータパケットの伝送および第3のデータパケットの受信は、第1のデータパケットの伝送の実質的に所定の長さの時間の後に、第3のデータパケットが受信されるように連動している。
特定の実施は、以下の1つ以上の特徴を含み得る。第2のデータパケットは、第2のデータパケットのデータフィールドに配置する任意の非充填データを第1のノードが有しているか否かに関わらず伝送され得る。第1、第2、および第3のデータパケットの各々は、それぞれのフロー制御情報を含み得る。第1および第2のデータパケットにおけるフロー制御情報は、第1のノードに関係しており、第3のデータパケットにおけるフロー制御情報は、第2のノードに関係している。フロー制御情報は、複数のチャネルに対する別個のフロー制御情報を含み得る。第1のデータパケットは、複数のチャネルのうちのどのチャネルに非充填データが伝送されているかを示すヘッダ情報を含んでいる。第1および第2のデータパケットの各々は、第1のノードの欠陥状態の表示を含んでいる。第3のデータパケットは、第2のノードの欠陥状態の表示を含んでいる。第1、第2、および第3のデータパケットは、同じ長さを有し得る。
第1のノードにおいて、第4のデータパケットが受信され得る。第4のデータパケットは、第2のノードから伝送され、第2のデータパケットが第2のノードによって正しく受信されたか否かを示す受信確認情報を含んでいる。第2のデータパケットの伝送および第4のデータパケットの受信は、第2のデータパケットの伝送の実質的に所定の時間の後に、第4のデータパケットが受信されるように連動している。第3のデータパケットが受信される前に、第1のノードにおいて第5のデータパケットが受信される。第5のデータパケットは、第3のデータパケットの前に、第2のノードから伝送され、第5のデータパケットは、特定のデータパケットが第2のノードによって正しく受信されたか否かを示す受信確認情報を含んでいない。
別の局面において、第1のノードと第2のノードとの間でデータパケットを同期的に通信することを含む方法およびコンピュータプログラム製品が提供される。データパケットは、第2のノードによる受信の受信確認を待機することなしに、第1のノードから伝送される。第1のノードにおいて、所定のデータパケットの受信の受信確認が、第2のノードから引き続き受信される。受信確認は、所定のデータパケットの伝送後、実質的に所定の時間に受信され、改悪されていない所定のデータパケットを第2のノードが受信したことを示している。特定の実施において、特定のデータパケットの受信の受信確認が、特定のデータパケットの伝送後の実質的に所定の時間に受信されない場合に、特定のデータパケットは再伝送され得る。
さらに別の局面において、第1のノードから第2のノードに第1のデータパケットを伝送することを含む方法が提供される。第1のデータパケットは、第1のノードからの非充填データを含む第1のデータフィールドを含んでいる。第2のノードにおいて、第1のデータパケットが受信され、第1のデータパケットの受信は、有限の長さの時間を要する。第1のデータパケットの受信が始まった後、第1のデータパケットの受信が終了する前に、第2のノードから第1のノードへの第2のデータパケットの伝送が開始される。第1のノードにおいて、第2のデータパケットが受信され、第2のデータパケットの受信は、有限の長さの時間を有する。第1のデータパケットの伝送が終了した後、第2のデータパケットの受信が開始した後、および第2のデータパケットの受信が終了する前に、第1のノードから第2のノードへの第3のデータパケットの伝送が開始される。第3のデータパケットの伝送は、第1のデータパケットに対応する任意の受信確認情報が、第2のノードから受信される前に開始される。第2のノードにおいて、第3のデータパケットが受信され、第3のデータパケットの受信は、有限の時間を要する。第2のデータパケットの伝送が終了した後、第3のデータパケットの受信が開始した後、および第3のデータパケットの受信が終了する前に、第2のノードから第1のノードへの第4のデータパケットの伝送が開始される。第4のデータパケットの伝送は、第2のデータパケットに対応する任意の受信確認情報が、第1のノードから受信される前に開始される。第4のデータパケットは、第1のデータパケットが第2のノードによって正しく受信されたか否かを示す受信確認情報を含んでいる。第1のデータパケットの伝送および第4の伝送は、第1のデータパケットの伝送の実質的に所定の長さの時間の後に、第4のデータパケットが伝送されるように連動している。第1のノードにおいて、第4のパケットが受信され、第1のノードにおいて、第1のデータパケットが正しく受信されたか否かを示す受信確認情報が処理される。第1のノードは、第1のデータパケットが第2のノードにおいて正しく受信されない場合に、第1のデータパケットを再伝送する。
特定の実施形態は、以下の利点の1つ以上を実現するように実施され得る。送信器および受信器は、非常に正確に(例えば、実質的に10マイクロ秒以下の範囲に)同期化され得る。遅延は制限され、(例えば、実質的に10マイクロ秒未満に)低く保たれる。単一の物理経路コネクタ(physical path connector)上において、データは、小さな遅延で伝送され得る。単一のシステムにおいて、異なる速度で動作する複数の通信リンクに対し、同じ通信プロトコルが用いられ得る。通信プロトコルは、ハードウェアに安価に実施される。帯域幅は、データ伝送に用いられ得るが、そうでない場合は、受信確認を待機するために用いられ得る。エラー検出とリカバリとが、フロー制御情報と受信確認情報とに同時に実行される。欠陥情報は、システムのいたるところに迅速に伝送され得る。異なる優先順位にある複数の独立なデータストリームは、システムのいたるところに伝送され得る。
これらの一般的および特定の局面は、方法、装置、システム、あるいは、方法、装置、およびシステムの任意の組み合わせを用いて実施され得る。
本発明の1つ以上の実施形態の詳細は、添付の図面および以下の詳細な記述において開示される。本発明のその他の特徴、局面、および利点は、詳細な記述、図面、および請求の範囲から理解され得る。
様々な図面における同じ参照番号および参照記号は、同じ要素を示す。
本発明は、さらに以下の手段を提供する。
(項目1)
第1のノードから第2のノードに第1のデータパケットを伝送することであって、該第1のデータパケットは、該第1のノードからの非充填データを含む第1のデータフィールドを含んでいる、ことと、
該第1のデータパケットの伝送後に、該第1のノードから該第2のノードに第2のデータパケットを伝送することであって、該第2のデータパケットの伝送は、該第1のデータパケットに対応する任意の受信確認情報が該第2のノードから受信される前に開始する、ことと、
該第1のノードにおいて第3のデータパケットを受信することであって、該第3のデータパケットは、該第2のノードから伝送され、該第3のデータパケットは、該第1のデータパケットが該第2のノードによって正しく受信されたか否かを示す受信確認情報を含んでおり、該第1のデータパケットの伝送および該第3のデータパケットの受信は、該第1のデータパケットの伝送の実質的に所定の長さの時間の後に、該第3のデータパケットが受信されるように連動している、ことと
を包含する、方法。
(項目2)
前記第2のデータパケットは、該第2のデータパケットの第2のデータフィールドに配置する任意の非充填データを前記第1のノードが有しているか否かに関わらず伝送される、項目1に記載の方法。
(項目3)
前記第1、第2、および第3のデータパケットの各々は、それぞれのフロー制御情報を含んでおり、該第1および第2のデータパケットにおける該フロー制御情報は、前記第1のノードに関係しており、該第3のデータパケットにおける該フロー制御情報は、前記第2のノードに関係している、項目1に記載の方法。
(項目4)
前記フロー制御情報は、複数のチャネルに対する別個のフロー制御情報を含む、項目3に記載の方法。
(項目5)
前記第1のデータパケットは、複数のチャネルのうちのどのチャネルに前記非充填データが伝送されているかを示すヘッダ情報を含んでいる、項目1に記載の方法。
(項目6)
前記第1および第2のデータパケットの各々は、前記第1のノードの欠陥状態の表示を含んでおり、
前記第3のデータパケットは、前記第2のノードの欠陥状態の表示を含んでいる、項目1に記載の方法。
(項目7)
前記第1、第2、および第3のデータパケットは、同じ長さを有している、項目1に記載の方法。
(項目8)
前記第1のノードにおいて第4のデータパケットを受信すること
をさらに含み、該第4のデータパケットは、前記第2のノードから伝送され、前記第2のデータパケットが該第2のノードによって正しく受信されたか否かを示す受信確認情報を含んでおり、該第2のデータパケットの伝送および該第4のデータパケットの受信は、該第2のデータパケットの伝送の実質的に所定の長さの時間の後に、該第4のデータパケットが受信されるように連動している、項目1に記載の方法。
(項目9)
前記第3のデータパケットが受信される前に、前記第1のノードにおいて第5のデータパケットを受信すること
をさらに含み、該第5のデータパケットは、該第3のデータパケットの前に、前記第2のノードから伝送され、該第5のデータパケットは、特定のデータパケットが該第2のノードによって正しく受信されたか否かを示す受信確認情報を含んでいない、項目1に記載の方法。
(項目10)
第1のノードと第2のノードとの間でデータパケットを同期的に通信すること
を含む方法であって、該同期的に通信することは、
該第2のノードによる受信の受信確認を待機することなしに、該第1のノードからデータパケットを伝送することと、
該第1のノードにおいて、該第2のノードから所定のデータパケットの受信の受信確認を引き続き受信することであって、該受信確認は、所定のデータパケットの伝送後、実質的に所定の時間に受信され、該受信確認は、改悪されていない所定のデータパケットを該第2のノードが受信したことを示している、ことと
を含む、方法。
(項目11)
同期的に通信することは、特定のデータパケットの受信の受信確認が、該特定のデータパケットの伝送後の実質的に所定の時間に受信されない場合に、該特定のデータパケットを再送信することをさらに含む、項目10に記載の方法。
(項目12)
第1のノードから第2のノードに第1のデータパケットを伝送することであって、該第1のデータパケットは、該第1のノードからの非充填データを含む第1のデータフィールドを含んでいる、ことと、
該第2のノードにおいて、該第1のデータパケットを受信することであって、該第1のデータパケットの受信は、有限の長さの時間を要する、ことと、
該第1のデータパケットの受信が始まった後、該第1のデータパケットの受信が終了する前に、該第2のノードから該第1のノードへの第2のデータパケットの伝送を開始することと、
該第1のノードにおいて、該第2のデータパケットを受信することであって、該第2のデータパケットの受信は、有限の長さの時間を要する、ことと、
該第1のデータパケットの伝送が終了した後、該第2のデータパケットの受信が開始した後、および該第2のデータパケットの受信が終了する前に、該第1のノードから該第2のノードへの第3のデータパケットの伝送を開始することであって、該第3のデータパケットの伝送は、該第1のデータパケットに対応する任意の受信確認情報が、該第2のノードから受信される前に開始される、ことと、
該第2のノードにおいて、該第3のデータパケットを受信することであって、該第3のデータパケットの受信は、有限の長さの時間を要する、ことと、
該第2のデータパケットの伝送が終了した後、該第3のデータパケットの受信が開始した後、および該第3のデータパケットの受信が終了する前に、該第2のノードから該第1のノードへの第4のデータパケットの伝送を開始することであって、該第4のデータパケットの伝送は、該第2のデータパケットに対応する任意の受信確認情報が、該第1のノードから受信される前に開始され、該第4のデータパケットは、該第2のノードによって該第1のデータパケットが正しく受信されたか否かを示す受信確認情報を含んでおり、該第1のデータパケットの伝送および該第4のデータパケットの伝送は、該第1のデータパケットの伝送の実質的に所定の長さの時間の後に、該第4のデータパケットが伝送されるように連動している、ことと、
該第1のノードにおいて、該第4のパケットを受信することと、
該第1のノードにおいて、該第1のデータパケットが正しく受信されたか否かを示す受信確認情報を処理することであって、該第1のノードは、該第1のデータパケットが該第2のノードにおいて正しく受信されない場合に、該第1のデータパケットを再伝送する、ことと
を含む、方法。
(項目13)
コンピュータ読取り可能な媒体に明確に具体化されたコンピュータプログラム製品であって、該コンピュータプログラム製品は、
第1のノードから第2のノードに第1のデータパケットを伝送することであって、該第1のデータパケットは、該第1のノードからの非充填データを含む第1のデータフィールドを含んでいる、ことと、
該第1のデータパケットの伝送の後に、第2のデータパケットを該第1のノードから該第2のノードに伝送することであって、該第2のデータパケットの伝送は、該第1のデータパケットに対応する任意の受信確認情報が該第2のノードから受信される前に開始される、ことと、
該第1のノードにおいて第3のデータパケットを受信することであって、該第3のデータパケットは、該第2のノードから伝送され、該第3のデータパケットは、該第1のデータパケットが該第2のノードによって正しく受信されたか否かを示す受信確認情報を含んでおり、該第1のデータパケットの伝送および該第3のデータパケットの受信は、該第1のデータパケットの伝送の実質的に所定の長さの時間の後に、該第3のデータパケットが受信されるように連動している、ことと
を含む動作をプログラム可能なプロセッサに実行させるように動作することが可能な命令を備えている、コンピュータプログラム製品。
(項目14)
前記第2のデータパケットは、該第2のデータパケットの第2のデータフィールドに配置する任意の非充填データを前記第1のノードが有しているか否かに関わらず伝送される、項目13に記載のコンピュータプログラム製品。
(項目15)
前記第1、第2、および第3のデータパケットの各々は、それぞれのフロー制御情報を含んでおり、該第1および第2のデータパケットにおける該フロー制御情報は、前記第1のノードに関係しており、該第3のデータパケットにおける該フロー制御情報は、前記第2のノードに関係している、項目13に記載のコンピュータプログラム製品。
(項目16)
前記フロー制御情報は、複数のチャネルに対する別個のフロー制御情報を含む、項目15に記載のコンピュータプログラム製品。
(項目17)
前記第1のデータパケットは、複数のチャネルのうちのどのチャネルに前記非充填データが伝送されているかを示すヘッダ情報を含んでいる、項目13に記載のコンピュータプログラム製品。
(項目18)
前記第1および第2のデータパケットの各々は、前記第1のノードの欠陥状態の表示を含んでおり、
前記第3のデータパケットは、前記第2のノードの欠陥状態の表示を含んでいる、項目13に記載のコンピュータプログラム製品。
(項目19)
前記第3のデータパケットが受信される前に、前記第1のノードにおいて第5のデータパケットを受信することであって、該第5のデータパケットは、該第3のデータパケットの前に、前記第2のノードから伝送され、該第5のデータパケットは、特定のデータパケットが該第2のノードによって正しく受信されたか否かを示す受信確認情報を含んでいない、こと
を含む動作を実行するように動作することが可能な命令をさらに備えている、項目13に記載のコンピュータプログラム製品。
(項目20)
コンピュータ読取り可能な媒体に明確に具体化されたコンピュータプログラム製品であって、該コンピュータプログラム製品は、
第1のノードと第2のノードとの間でデータパケットを同期的に通信することと、
該第1のノードにおいて、該第2のノードから所定のデータパケットの受信の受信確認を引き続き受信することであって、該受信確認は、所定のデータパケットの伝送後、実質的に所定の時間に受信され、該受信確認は、改悪されていない所定のデータパケットを該第2のノードが受信したことを示している、ことと
を含む動作をプログラム可能なプロセッサに実行させるように動作することが可能な命令を備えている、コンピュータプログラム製品。
(摘要)
第1のノードと第2のノードとの間でデータパケットを同期的に通信する方法、装置、およびコンピュータプログラム製品が提供される。データパケットは、第2のノードによる受信の受信確認を待機することなしに、第1のノードから伝送される。引き続き、第1のノードにおいて、所定のデータパケットの受信の受信確認が受信される。受信確認は、所定のデータパケットの伝送後、実質的に所定の時間に受信される。受信確認は、第2のノードが改悪されていない所定のデータパケットを受信したことを示す。
(詳細な記述)
2つのシステムノードの間で全2重(full−duplex)シリアルデータの実質的に連続なストリームを用いるリンク層が記述されている。ノードは、例えば、コンピュータ、プログラム可能なプロセッサ、フィールドプログラマブルゲートアレイ(FPGA)、または、その他のデータ処理装置を含み得る。データは、固定長のパケットに分割される。固定長のパケットの各々は、データ、エラー検査情報、フロー制御情報、診断情報、欠陥情報、および再伝送制御情報を含んでいる。各パケットにおけるデータは、ハードウェアレベルのデータまたはメッセージ(例えば、ソフトウェアメッセージ)の一部を含み得る。
固定長のパケットは、データが伝送に利用可能であるか否かに関わらず、2つのノードの間で連続的に伝送される。伝送に利用可能なデータが存在しない場合、パケットのデータフィールドは、「充填(filler)」データを用いて充填され得、上記充填データは、受信ノードにおいて放棄され得る。伝送されたパケットは、既に受信されたパケットの受信確認(acknowledgement)を含んでいる。伝送ノードは、第1のパケットを伝送し、受信ノードから第1のパケットの受信確認を受信する前に、以後に続くパケットを少なくとも1つ伝送し始め得る。以下でさらに詳細に記述され得るように、ノードにおけるパケットの伝送および受信は、連動している。
図1に示されるように、第1のノード110からのデータは、リンク上でデータを多重化することにより、複数の宛先ノード、例えば、第2のノード120、第3のノード130、および第4のノード140に伝送され得る。第1のノード110と特定の宛先ノードとの間にあるノードは、データをルーティングし得る。第1のノード110は、第1のリンク125を介することにより、第2のノード120に対するデータを伝送し得る。第1のノード110はまた、第1のリンク125を介することにより、第3のノード130に対するデータを第2のノード120に伝送し、第2のノード120は、第2のリンク135を介することにより、上記データを第3のノード130にルーティングし得る。同様に、第1のノード110は、第1のリンク125を介することにより、第4のノード140に対するデータを伝送し、第2のノード120は、第3のリンク145を介することにより、上記データを第4のノード140に伝送し得る。
ある実施において、宛先ノードの宛先は、伝送されるデータに含まれているメッセージにおいて処理され得る。この実施において、典型的に第2のノード120は、メッセージの一部を含むパケットを宛先ノードに送信する前に、第1のノード110から送信されたメッセージの少なくとも一部分を処理する。第2のノード120それ自身が宛先ノードである場合、メッセージは、これ以上は伝送される必要はない。
いくつかのシステムにおいて、第1のノード110と第3のノード130および第4のノード140との間の通信は、第3のノード130と第4のノード140との間の通信が発生するよりも、より頻繁に発生する。そのようなシステムにおいて、第1のリンク125は、第1のリンク125を通過する大きなボリュームのデータに対して十分な容量を提供するために、第2のリンク135または第3のリンク145よりも高速のリンクであり得る。
ノード110、120、130、および140は、1つ以上のハードウェアデータバッファ152〜164を含み、上記ハードウェアバッファは、メッセージを受信し、それぞれのノード上またはそれぞれのノードと通信するデータ処理装置上で実行するソフトウェアがメッセージを受信する準備ができるまで、上記メッセージを保持し得る。
図2に示されているように、ある実施における固定長のパケット200は、複数のバイト201〜240を含み得る。40バイトのパケットが示されているが、固定長のパケットは、その他の長さでもあり得る。示されている実施において、制御情報は、40バイトのうちの8バイトに配置され、データは、残りの32バイトに配置されている。第1のバイト201は、同期化フィールドであり、上記同期化フィールドは、パケットを受信するノードにおいて、バイトの骨組み(framing)を維持するように用いられ得る。複数のノードの間のクロックドリフトを補償するために、追加的な同期化バイトが、(例えば128パケットごとに一度)定期的にパケットに追加され得る。第2のバイト202は、受信確認フィールドであり、上記受信確認フィールドは、パケット200を伝送するノードによって受信された最後のパケットが、正しく(例えば、有効なエラー検査情報を含んで)受信されたか否かを示し得る。第2のバイト202は、最後のパケットが正しく受信されたという肯定受信確認(ACK)を示すために、ある値(例えば、0xAC)に設定され、最後のパケットが正しく受信されなかったこと(例えば、否定受信確認またはNAK)を示すために、逆値(例えば、0x53)に設定され得る。ある実施において、肯定受信確認の値を除く任意の値は、否定受信確認としてインタープリットされ得る。この実施において、NAK値がACK値の逆である場合、8ビットのエラーは、伝送されたNAKをACKに転送するように要求される。
第3のバイト203は、応答フィールドであり、上記応答フィールドは、例えば、システムが診断テストモードにあることを示すテストモードビットや、複数のメッセージチャネル(例えば、低優先順位、中優先順位、高優先順位のチャネル)の各々に対するXOFFビットのような、複数の制御ビットを含んでいる。制御ビットはまた、再伝送ビットをも含み得、上記再伝送ビットは、設定されたときにパケット200が以前のパケットの再伝送であるということを示し得る。また、1つ以上の制御ビットは、欠陥ビットであり得、上記欠陥ビットは、システム内でエラーが発生したことを示し得る。
第4のバイト204は、ヘッダフィールドである。ヘッダフィールドは、例えばチャネル選択サブフィールドやコマンドサブフィールドのような、複数のサブフィールドを含み得る。チャネル選択サブフィールドは、パケット200内のデータが、どの優先順位のチャネル上に伝送されるのかを示すように用いられる。コマンドサブフィールドは、バッファをフラッシュ(flush)し、メッセージのストリームを再開するための命令を含み得る。コマンドサブフィールドは、特定のデータが、ハードウェアチャネル上、または、そのようなデータを識別するコード上に送信されることを要求する命令を含み得る。コマンドサブフィールドはまた、システムを同期化するようにも用いられる。例えば、同期化サイクルの開始において、同期化コマンドを含むパケットが送信され得、システム内のサブシステムが同期化(例えば、10マイクロ秒の範囲内)を維持することを可能にする。第5のバイト205は、受信ノードによって伝送エラーを検出するように用いられ得るシーケンス番号を含むシーケンス番号フィールドである。第6のバイト206から第37のバイト237までは、例えばメッセージまたはメッセージの一部のような、32バイトのデータを保持するデータフィールドに属している。
第38のバイト238は、パケット末端フィールドであり、上記パケット末端フィールドは、データフィールドにおけるどれだけのバイトがメッセージに対応し得るのかと、どれだけのバイトが充填バイトであるのかとを特定し得る。パケット末端フィールドはまた、パケット末端指示ビットをも含み得、上記パケット末端指示ビットは、データフィールドにおけるバイトがメッセージを終了するときに設定される。メッセージ末端指示ビットは、受信ノードにおける中断をトリガし得る。第39のバイト239および第40のバイト240は、エラー検査フィールドの一部であり、上記エラー検査フィールドは、一実施形態において、16ビットのCRC値(例えば、CCITT 16ビット CRC アルゴリズムを用いて計算される)を含み得る。ノードがパケットを受信すると、上記ノードは、エラー検査フィールドを用いることにより、パケットが伝送または受信されている最中にエラーが発生したか否かを決定し得る。
パケット200の構造は、ノード内の欠陥を示す欠陥反応論理(FRL;fault reaction logic)信号が、複数の方法で通信されることを可能にする。例えば、FRL信号は、パケット制御情報内に(例えば、パケット200の応答フィールドの制御ビット内に)、および/または、メッセージ内に伝送され得る。パケット制御情報内にFRL信号を直接的に伝送することは、欠陥情報がシステム全体にわたって非常に迅速に伝送され、非常に低いレベルで取り扱われることを可能にする。システム全体にわたる欠陥信号は、ソフトウェアの介入なしで伝播され得、欠陥反応ハードウェアは、欠陥信号が受信されると、システムを安全な状態に置き得る。欠陥を引き起こした問題が(例えば、人間のオペレータの介入によって)一旦解決されると、欠陥信号はクリアされ得、システムは動作可能状態に戻り得る。欠陥信号がクリアされると、典型的に欠陥を示しているFRL信号は、別の欠陥が発生するまで、パケット制御情報内に伝送されない。
欠陥信号の迅速な伝播が有利なシステムの例は、ロボット式手術システムである。そのようなシステムは、手術用の器具またはデバイス(例えば、腹腔鏡、内視鏡、照明、カメラ、および吸入器)を保持する複数のロボット式アームを含み得、そららのうちのいくつかは、患者の内部に位置し得る。典型的に、ロボット式アームは、外科医によって遠隔的に操作される。外科医が操作する制御と、ロボット式アームを制御するノードとの間の通信は、本明細書における開示に記述されている方法、システム、および装置を用い得る。そのようなシステムにおいてエラーが発生すると、患者がロボット式アームの予期せぬ動きによって傷付けられないようにするために、ロボット式アームは、所定の場所にロックされ得る。システムの欠陥が発生し、システムの欠陥が複数のノードの間に伝播すると、ロボット式アームの接合部にブレーキが加えられ得、上記欠陥が、人間のオペレータまたはシステム監視ユニットによって自動的にクリアされるまで、動きに関するコマンドの通信は、一時中断され得る。
記述されているパケット構造は、例えばメッセージのようなデータが、単一のチャネル上、または、シリアル接続上で多重化される複数のチャネル上に送信されることを可能にする。特定のメッセージが送信されるチャネルは、パケット200内のチャネル選択サブフィールドによって指示される。システムソフトウェアは、異なるハードウェアバッファにおけるメッセージを(例えば、異なるアドレスを用いることにより)各チャネルに配置し、システムハードウェアは、どのバッファにメッセージが配置されるかに基づいて、メッセージを自動的にチャネルに割り当て得る。複数のチャネルは、異なる優先順位が割り当てられ得る。ある実施において、異なる優先順位のメッセージが伝送されるのを待機している場合、高優先順位のチャネルに伝送されるデータを含むパケットまたはパケットのグループは、低優先順位のチャネルに伝送されるデータを含むパケットまたはパケットのグループよりも前に伝送される。別の実施において、高優先順位のチャネルに伝送されるデータを含むパケットは、低優先順位のチャネルに伝送されるデータを含むパケットよりも、より多くの伝送スロットを割り振られ得る。スピードが重視される(time−critical)メッセージは、高優先順位のチャネル上に伝送され得るが、比較的重要でないメッセージは、低優先順位のチャネル上に伝送され得る。一旦十分なデータがバッファに書き込まれ、パケットを充填すると、システムハードウェアは、メッセージの一部を自動的に伝送し得る。すなわち、メッセージの伝送は、データが利用可能になり、全メッセージがバッファに書き込まれるまで待機する必要がなくなった際に、実行され得る。
第3のバイト203内のXOFFビットは、チャネル内のデータのフローを制御する。各ノードは、複数のハードウェアバッファを含み得、上記ハードウェアバッファは、複数のチャネルの各々に伝送されたメッセージを受信し得る。例えば、高優先順位のメッセージは、高優先順位のバッファに格納され、低優先順位のメッセージは、低優先順位のバッファに格納される。パケット200を伝送する第1のノードがパケット200内のXOFFビットを設定するとき、第1のノードは、パケット200を受信する第2のノードに、それぞれのデータチャネル上で第1のノードにデータを伝送するのを停止するように命令する。第1のノードのハードウェアは、データチャネルに対して、例えば、第1のノードが上記データチャネルからのメッセージを格納するバッファが一杯になりそうなときに、XOFFビットを自動的に設定し得る。ある実施において、所定のチャネルに対してノードがいつXOFFビットを設定するかに関する閾値は、ノード内のそれぞれのチャネルの受信バッファのサイズ(例えば、512ワード)から32ワード(4パケット)を引いたものに等しく設定される。32ワードのマージンは、エラーに対するマージンを用いることにより、XOFF信号を受信し、それに反応した動作をとる時間を、受信ノードに与える。その他の閾値レベルもまた、可能である。第1のノードのハードウェアはまた、多数(例えば、12個)のメッセージが受信バッファに存在するときに、データチャネルに対するXOFFビットを設定し得る。一旦パケットまたはメッセージがバッファから取り除かれると、ハードウェアは、データチャネルに対するXOFFビットを自動的にクリアし得る。各優先順位チャネルは、ノード内のそれぞれの受信バッファを有し得る。XOFFビットはすべてのパケット内に伝送されるので、エラー検査フィールドがXOFFビットに適用され、XOFFビットの改悪(corruption)をガードし得る。
上述のチャネル選択サブフィールドを用いることにより、複数の通信チャネルがリンク層において利用可能にされ得る。例えば、ハードウェアチャネルと、高優先順位、中優先順位、低優先順位のチャネルとが、実装され得る。メッセージは、長さが(例えば、3ワードから128ワードの間に)変動し得、メッセージの長さに依存して、1つ以上のパケットに伝送され得る。メッセージの第1のバイトは、メッセージの宛先ノードのアドレスを含み得る。システムハードウェアは、伝送ノードにおいて、メッセージを複数のパケットに細分化し、受信ノードにおいて、メッセージをデフラグし得る。メッセージがパケットのデータ部分を充填していない場合、データ部の残部に充填データが挿入され得る。メッセージの伝送バッファと受信バッファとが、ハードウェア内に実装され得る。例えば、ノードは、各チャネル(例えば、高優先順位、中優先順位、低優先順位のチャネル)に対し、ハードウェアの伝送バッファと受信バッファとを含み得る。ある実施において、上記チャネルに対する伝送バッファおよび受信バッファは、最大のメッセージサイズの1.5倍である。
図3は、図2の文脈で議論されたようなパケットを用いることによる2つのノードの間の通信のための概念的なタイミング図を示している。パケット301〜304は、第1のノードから第2のノードへと連続的に伝送される。パケット311〜314は、第2のノードで受信され、パケット301〜304に対応しているが、パケット311〜314は、伝送エラーが発生した場合は、それぞれのパケット301〜304の改悪版であり得る。時間の経過にともない、パケット311〜314の受信は、リンクに沿ったパケットの有限の伝播時間のために、パケット301〜304伝送に関して遅延される。図3に示されている例において、パケットの伝播時間は、パケットの持続時間(パケットを伝送するために第1のノードによって要求される時間の長さ)よりも短い。
第2のノードは、パケット355〜358を第1のノードに伝送する。パケット365〜368は、第1のノードにおいて遅延の後に受信され、パケット355〜358に対応している。パケット356は、パケット301に適用される受信確認フィールドを含む。パケット311(パケット301に対応する)が第2のノードにおいて正しく受信された場合、パケット356は、パケット301に対するACKを含む。パケット311が正しく受信されなかった場合、パケット356は、NAKを含む。パケット357は、パケット302に対応する受信確認フィールドを含む。同様に、パケット303は、第1のノードにおいてパケット365が同時に受信されたか否かを示す受信確認フィールドを含み、パケット304は、パケット366に対する受信確認フィールドを含む。
ある実施において、第2のノードは、第1の受信確認フィールドが第1のノードから受信されるまで、パケットの伝送を開始しない。例えば、第2のノードは、第2のノードがパケット311内の受信確認フィールドを受信するまで、パケット355の伝送を開始しない。第1のノードと第2のノードとの間の初期同期化を容易にするために、2つのノードは、第1のノードがパケット301を伝送する前に、いくつかの連続的な同期化バイトを各々伝送し得る。
図3は、第1のノードと第2のノードとの間に2つのパケットの「パイプライン」が存在する場合を示している。パケット356は、パケット301に対する受信確認フィールドを含む。受信確認フィールドがACKを含む場合、第1のノードは、パケット303を伝送する。しかしながら、パケット356の受信確認フィールドがNAKを含む場合、第1のノードは、パケット301および302をリフレームし、再伝送し得る。システムを再同期化するために、この実施において、2つのパケットは、2つのパケットのうちの第1のパケットに対してNAKが受信されたときに、再伝送され得る。2つのパケットのうちの第1のパケットが正しく受信されなかった場合、第2のパケットは、第2のパケットがはじめて伝送されたときに、第2のパケットが正しく受信されたか否かをチェックすることなしに、再伝送され得る。2つのノードの間の同期化の損失により、第1のパケットにおけるエラーが発生したという状況において、第2のパケットはエラーを含むと考えられるため、第2のパケットは先制的に(preemptively)伝送される。NAKを伝送したノードもまた、NAKを伝送する前に伝送された最後の2つのパケットを再伝送し得る。所定のパケットに対し、受信確認フィールドは、別のパケットが伝送された後にのみ受信されるため、図3は、第1のノードと第2のノードとの間に2つのパケットのパイプラインを有するように記述されている。第1のノードと第2のノードとの間の往復時間は、1つのパケットを伝送するのに要求される時間と同じか、わずかに短い。すなわち、第1のノードは、第1のノードがパケット301の伝送を終了するよりも前に、パケット365の受信を開始し得る。典型的に、往復時間は、リンク上の伝播の遅延と、ノードにおける処理時間とに依存する。システム内では、より長い往復時間(絶対時間が長い、または、パケットの持続時間に関する時間が長い)もまた、使用され得、結果として、パイプラインは、2つのパケットよりも深く(deep)なり得る。
パケットは、パケットのデータフィールドに位置するメッセージが存在するか否かに関わらず、第1のノードと第2のノードとの間で実質的に連続的に伝送される。図3に示されているように、パケットは、連動的な方法で伝送される。固定長のパケットの連動的な伝送は、ノードにおいて受信されたパケットと、ノードによって伝送されたパケットとの間で、位相が固定されたオフセットを発生し得る。ノードは、既に伝送されたパケットの伝送から所定の長さの時間の後、既に伝送されたパケットのエラーのない受信の受信確認を含むパケットを、遠隔ノードから受信する。連動したパケットの連続的な伝送は、複数のノードの間の正確な同期化と共に、高帯域幅、低遅延の通信を可能にする。加えて、パケットの連続的な伝送は、システムが複数のノードの間の接続のビットエラーレート(BER;bit error rate)を正確かつ実質的に連続的に計算することを可能にする。
図4に示されているように、第2のノードが、第1のノードからパケット411を受信し、パケット411におけるデータの改悪を引き起こす伝送エラーが発生したことを決定するとき、第2のノードは、次のパケットを伝送する代わりに、パケットの伝送を終了し、第1のノードにNAKとリフレーミングシーケンス(reframing sequence)456とを伝送する。パケット411が改悪され得る理由の1つは、第1のノードと第2のノードとの間の同期化が低下すること、または、損失することにあるため、リフレーミングシーケンス456が伝送され、第1のノードと第2のノードとの間の同期化を再構築する。リフレーミングシーケンスは、代替的な同期化フィールドとリンクフィールドとを含み得、上記リンクフィールドは、例えば0xA3のような所定のコードであり得る。ある実施において、ノードがリフレームされることを考慮される前に、第4のリンクのバイトが受信されなければならない。第1のノードは、NAKとリフレーミングシーケンス466とを受信し、リフレーミングシーケンス403を伝送する。第1のノードがリフレーミングシーケンス403を伝送した後、第1のノードは、NAKを受信する前に伝送された最後のパケットを再送信する。N個のパケットのパイプラインの場合、最後のN個のパケットが再送信される。一旦、第2のノードが、第1の再伝送されたパケット414におけるACKを受信すると、第2のノードはまた、パケットの再伝送を開始する。
図5に示されているように、第1のノードが第2のノードからパケット565を受信し、パケット565におけるデータの改悪を引き起こす伝送エラーが発生したことを決定するとき、第1のノードは、NAKとリフレーミングシーケンス503とを、第2のノードに送信する。第2のノードは、NAKとリフレーミングシーケンス513とを受信し、リフレーミングシーケンス557を送信する。第1のノードがNAKとリフレーミングシーケンス503とを伝送した後、第1のノードは、改悪されたパケットを受信する前に伝送された最後のパケットを再送信する。一旦、第2のノードが第1の再伝送されたパケット514内のACKを受信すると、第2のノードはまた、パケットの再伝送を開始する。
エラーカウンタは、ノード内で発生するハードウェアの伝送エラーの回数を追跡し得る。カウンタが閾値に到達したときに、中断がイネーブルにされ得る。ある実施において、エラーカウンタは、ノード内のソフトウェアによって読み取られ、上記ソフトウェアは、中断の閾値を設定し得る。このシステムにおいて、エラーの検出および修正は、非常に低いレベルで扱われ得、記述されたリンク層の最上位で動作するソフトウェア層は、追加的なエラーの検出および修正を実施する必要がない。
図6は、ある実施におけるノードにおいて実行される処理600を示している。ノードは、第1のパケットの受信を開始し(ステップ610)、第1のパケットにおける受信確認フィールドを受信する(ステップ615)。ノードは、受信確認フィールドが、ACKであるか、NAKであるかを決定する(ステップ620)。受信確認フィールドがNAKである場合、ノードはリフレーミングシーケンスを伝送し(ステップ625)、受信したNAKがそのパケットの後に伝送された任意のパケットに対応するようなパケットを再伝送する(ステップ630)。受信確認フィールドがACKである場合、ノードは第2のパケットの伝送を開始し(ステップ635)、例えば、上記パケット内のCRC値を検証することにより、第1のパケットのエラーをチェックする(ステップ640)。第1のパケットにおいてエラーが検出された場合、ノードは、第2のパケットの伝送を終了し(ステップ645)、NAKとリフレーミングシーケンスとを伝送する(ステップ650)。
第1のパケットにおいてエラーが検出されなかった場合、ノードは、第1のパケットにおいて欠陥ビットが設定されたか否かを決定する(ステップ655)。欠陥ビットが設定された場合、ノードは、欠陥モードまたは安全状態に置かれる(ステップ660)。欠陥ビットが設定されていない場合、または、一旦ノードが欠陥モードに置かれると、ノードは第2のパケットの伝送を終了し(ステップ665)、第3のパケットの伝送を開始する(ステップ670)。
本発明の実施形態、および、本明細書に記述された機能的な動作のすべては、デジタル電子回路、または、コンピュータのソフトウェア、ファームウェア、または、ハードウェアに実装され得、本明細書に記述された構造、それらの構造上の等価物、あるいは、それらのうちの1つ以上の組み合わせを含み得る。本発明の実施形態は、1つ以上のコンピュータプログラム製品として、すなわち、データ処理装置によって実行されるか、または、データ処理装置の動作を制御するための、コンピュータ読取り可能な媒体上に符号化されたコンピュータプログラム命令の1つ以上のモジュールとして、実装され得る。コンピュータ読取り可能な媒体は、機械読取り可能な格納デバイス、機械読取り可能な格納基板、メモリデバイス、機械読取り可能な伝播信号に作用する構成、または、それらの1つ以上の組み合わせであり得る。「データ処理装置」という用語は、例えばプログラム可能なプロセッサ、コンピュータ、または、複数のプロセッサまたはコンピュータを手段として含む、データを処理するための装置、デバイス、および機械のすべてを包含する。上記装置は、ハードウェアに加え、問題となっているコンピュータプログラムに対する実行環境を形成するコードを含み得、上記コードは、例えば、プロセッサファームウェア、プロトコルスタック、データベース管理システム、オペレーティングシステム、または、それらのうちの1つ以上の組み合わせを構成するコードであり得る。伝播信号は、人工的に生成された信号、例えば、機械によって生成された電気的、光学的、または、電磁気的な信号であり得、適切な受信装置に伝送するために、情報をエンコードするように生成され得る。
コンピュータプログラム(プログラム、ソフトウェア、ソフトウェアアプリケーション、スクリプト、またはコードとしても知られる)は、コンパイルまたはインタープリットされた言語を含む、任意の形式のプログラム言語で書かれ得、スタンドアロンなプログラムとして、または、モジュール、コンポーネント、サブルーチンとして、または、コンピューティング環境における使用に適したその他のユニットとしてを含む、任意の形態で配信され得る。コンピュータプログラムは、必ずしもファイルシステム内のファイルに対応してはいない。プログラムは、その他のプログラムまたはデータ(例えば、マークアップ言語のドキュメントに格納された1つ以上のスクリプト)を保持するファイルの一部に、問題となっているプログラム専用の単一のファイルに、または、(例えば、1つ以上のモジュール、サブプログラム、または、コードの一部を格納する)組織化された複数のファイルに格納され得る。コンピュータプログラムは、1つの場所に位置しているか、または、複数の場所に分散し、通信ネットワークによって相互接続されている、1つ以上のコンピュータ、または、複数のコンピュータの上で実行されるように配信され得る。
本明細書に記述された処理および論理の流れは、1つ以上のコンピュータプログラムを実行する1つ以上のプログラム可能なプロセッサによって実行され得、データを入力し、出力を生成するように動作することにより、複数の機能を実行する。処理および論理の流れはまた、例えばFPGA(field programmable gate array)またはASIC(application−specific integrated circuit)のような特定用途向け論理回路によって、実行され得、装置もまた、上記のような特定用途向け論理回路として、実施され得る。
コンピュータプログラムの実行に適したプロセッサは、例えば、汎用プロセッサと特定用途向けプロセッサとの両方、任意の種類のデジタルコンピュータの1つ以上の任意のプロセッサを含む。一般に、プロセッサは、命令とデータとを、読み出し専用メモリまたはランダムアクセスメモリまたはその両方から受信し得る。コンピュータの主要な要素は、命令を実行するためのプロセッサ、および、命令とデータとを格納するための1つ以上のメモリである。一般に、コンピュータは、データを格納するために、1つ以上の大容量の格納デバイス、例えば、磁気ディスク、磁気光学ディスク、または、光学ディスクを含み得、あるいは、データを受信するように、または、データを伝送するように、または、受信と伝送との両方を行なうように、上記格納デバイスに動作可能なように接続される。しかしながら、コンピュータは、必ずしもそれらのデバイスを有する必要はない。さらに、コンピュータは、別のデバイス、例えば、わずかな例を挙げると、携帯電話、パーソナルデジタルアシスタント(PDA)、携帯型オーディオプレイヤー、全地球測位システム(GPS)受信器に埋め込まれ得る。コンピュータプログラムの命令およびデータを格納するのに適したコンピュータ読取り可能な媒体は、任意の形態の不揮発性メモリ、メディア、および、メモリデバイスを含み、例えば、半導体メモリデバイス(例えば、EPROM,EEPROM、フラッシュスメモリデバイス)、磁気ディスク(例えば、内蔵式のハードディスクまたはリムーバブルディスク)、磁気光学ディスク、ならびに、CD−ROMディスクおよびDVD−ROMディスクを含む。プロセッサおよびメモリは、特定用途向け論理回路によって補完されるか、特定用途向け論理回路に実装され得る。
ユーザとの相互作用を提供するために、本発明の実施形態は、ユーザに情報を表示するための、例えばCRT(陰極線管)またはLCD(液晶ディスプレイ)のようなディスプレイデバイスと、ユーザにコンピュータへの入力を提供するための、キーボードと例えばマウスまたはトラックボールのようなポインティングデバイスとを有するコンピュータに実装され得る。その他の種類のデバイスも同様に、ユーザとの相互作用を提供するために用いられ得る。例えば、ユーザに提供されたフィードバックは、任意の形態の知覚性フィードバックであり得、例えば、視覚性のフィードバック、音響性のフィードバック、または、触覚性のフィードバックであり得る。また、ユーザからの入力は、任意の形態で受信され得、上記入力は、音響性の入力、発話による入力、または、触覚性の入力を含み得る。
本明細書は、多くの具体例を含んでいるが、これらは、本発明またはクレームされている内容の範囲を制限するものとして考えられるべきではなく、むしろ、本発明の特定の実施形態に特有の特徴を記述しているものとして考えられるべきである。別個の実施形態の文脈で本明細書に記述されている特定の特徴はまた、単一の実施形態に組み合わせ的に実施され得る。逆に、単一の実施形態の文脈で記述されている様々な特徴は、複数の実施形態に別個に実施され得るか、または、任意の適切な小結合(subcombination)で実施され得る。さらに、上述では、特徴は、特定の組み合わせに作用するように記述されているが、いくつかの場合において、クレームされた組み合わせからの1つ以上の特徴は、上記の組み合わせから切り取られたようにさえもクレームされ得、クレームされた組み合わせは、小結合または小結合のバリエーションに向けられ得る。
同様に、図面において、動作は特定の順序で記述されているが、このことは、示されているそのような特定の順序または連続的な順序で実行されること、あるいは、示されているすべての動作が望ましい結果を達成するように実行されることを要求していると理解されるべきではない。特定の状況において、マルチタスク処理および並列処理は、有利であり得る。さらに、上記で記述された実施形態における様々なシステムコンポーントの分離は、すべての実施形態においてそのような分離を要求しているものとして理解されるべきではなく、記述されたプログラムコンポーネントおよびシステムは、一般に、単一のソフトウェア製品に互いに統合されるか、または、複数のソフトウェア製品にパッケージ化され得ると理解されるべきである。
このようにして、本発明の特定の実施形態が記述されてきた。その他の実施形態は、以下の請求項の範囲内にある。例えば、請求項に挙げられた動作は、異なる順序で実行され得、望ましくない結果を達成しさえもし得る。上記で記述された方法、システム、および装置は、光ファイバー(例えば、160Mb/秒で動作する)、低電圧の差分信号(例えば、122Mb/秒で動作する)、ソース同期式シリアル、非同期なバックプレーンワイヤを含む、様々な物理的な伝送機構と共に用いられ得る。ある実施において、改悪されたパケットは、上記パケットがエラーを許容し得るデータを含んでいるときには、必ずしも再伝送されない。例えば、ビデオストリームまたはオーディオストリームにおいて時々発生する誤動作は、許容可能である。さらに、エラー検出およびリフレーミングが、この実施に使用され、ハードウェアによって実施されるフレーミングエラーからの高速のリカバリを可能にする。
以上のように、本発明の好ましい実施形態を用いて本発明を例示してきたが、本発明は、この実施形態に限定して解釈されるべきものではない。本発明は、特許請求の範囲によってのみその範囲が解釈されるべきであることが理解される。当業者は、本発明の具体的な好ましい実施形態の記載から、本発明の記載および技術常識に基づいて等価な範囲を実施することができることが理解される。
リンクによって接続された複数のノードを含むシステムのブロック図である。 データパケットの構造の図である。 複数のノードの間のパケット伝送のタイミング図である。 エラーリカバリのシナリオのタイミング図である。 エラーリカバリのシナリオのタイミング図である。 ノードにおいて実行される処理のフローチャートである。
符号の説明
200 データパケット
201 同期化フィールド
202 受信確認フィールド
203 応答フィールド
204 ヘッダフィールド
205 シーケンス番号フィールド
206〜237 データフィールド
238 パケット末端フィールド
239、240 エラー検査フィールド

Claims (20)

  1. 第1のノードから第2のノードに第1のデータパケットを伝送することであって、該第1のデータパケットは、該第1のノードからの非充填データを含む第1のデータフィールドを含んでいる、ことと、
    該第1のデータパケットの伝送後に、該第1のノードから該第2のノードに第2のデータパケットを伝送することであって、該第2のデータパケットの伝送は、該第1のデータパケットに対応する任意の受信確認情報が該第2のノードから受信される前に開始する、ことと、
    該第1のノードにおいて第3のデータパケットを受信することであって、該第3のデータパケットは、該第2のノードから伝送され、該第3のデータパケットは、該第1のデータパケットが該第2のノードによって正しく受信されたか否かを示す受信確認情報を含んでおり、該第1のデータパケットの伝送および該第3のデータパケットの受信は、該第1のデータパケットの伝送の実質的に所定の長さの時間の後に、該第3のデータパケットが受信されるように連動している、ことと
    を包含する、方法。
  2. 前記第2のデータパケットは、該第2のデータパケットの第2のデータフィールドに配置する任意の非充填データを前記第1のノードが有しているか否かに関わらず伝送される、請求項1に記載の方法。
  3. 前記第1、第2、および第3のデータパケットの各々は、それぞれのフロー制御情報を含んでおり、該第1および第2のデータパケットにおける該フロー制御情報は、前記第1のノードに関係しており、該第3のデータパケットにおける該フロー制御情報は、前記第2のノードに関係している、請求項1に記載の方法。
  4. 前記フロー制御情報は、複数のチャネルに対する別個のフロー制御情報を含む、請求項3に記載の方法。
  5. 前記第1のデータパケットは、複数のチャネルのうちのどのチャネルに前記非充填データが伝送されているかを示すヘッダ情報を含んでいる、請求項1に記載の方法。
  6. 前記第1および第2のデータパケットの各々は、前記第1のノードの欠陥状態の表示を含んでおり、
    前記第3のデータパケットは、前記第2のノードの欠陥状態の表示を含んでいる、請求項1に記載の方法。
  7. 前記第1、第2、および第3のデータパケットは、同じ長さを有している、請求項1に記載の方法。
  8. 前記第1のノードにおいて第4のデータパケットを受信すること
    をさらに含み、該第4のデータパケットは、前記第2のノードから伝送され、前記第2のデータパケットが該第2のノードによって正しく受信されたか否かを示す受信確認情報を含んでおり、該第2のデータパケットの伝送および該第4のデータパケットの受信は、該第2のデータパケットの伝送の実質的に所定の長さの時間の後に、該第4のデータパケットが受信されるように連動している、請求項1に記載の方法。
  9. 前記第3のデータパケットが受信される前に、前記第1のノードにおいて第5のデータパケットを受信すること
    をさらに含み、該第5のデータパケットは、該第3のデータパケットの前に、前記第2のノードから伝送され、該第5のデータパケットは、特定のデータパケットが該第2のノードによって正しく受信されたか否かを示す受信確認情報を含んでいない、請求項1に記載の方法。
  10. 第1のノードと第2のノードとの間でデータパケットを同期的に通信すること
    を含む方法であって、該同期的に通信することは、
    該第2のノードによる受信の受信確認を待機することなしに、該第1のノードからデータパケットを伝送することと、
    該第1のノードにおいて、該第2のノードから所定のデータパケットの受信の受信確認を引き続き受信することであって、該受信確認は、所定のデータパケットの伝送後、実質的に所定の時間に受信され、該受信確認は、改悪されていない所定のデータパケットを該第2のノードが受信したことを示している、ことと
    を含む、方法。
  11. 同期的に通信することは、特定のデータパケットの受信の受信確認が、該特定のデータパケットの伝送後の実質的に所定の時間に受信されない場合に、該特定のデータパケットを再送信することをさらに含む、請求項10に記載の方法。
  12. 第1のノードから第2のノードに第1のデータパケットを伝送することであって、該第1のデータパケットは、該第1のノードからの非充填データを含む第1のデータフィールドを含んでいる、ことと、
    該第2のノードにおいて、該第1のデータパケットを受信することであって、該第1のデータパケットの受信は、有限の長さの時間を要する、ことと、
    該第1のデータパケットの受信が始まった後、該第1のデータパケットの受信が終了する前に、該第2のノードから該第1のノードへの第2のデータパケットの伝送を開始することと、
    該第1のノードにおいて、該第2のデータパケットを受信することであって、該第2のデータパケットの受信は、有限の長さの時間を要する、ことと、
    該第1のデータパケットの伝送が終了した後、該第2のデータパケットの受信が開始した後、および該第2のデータパケットの受信が終了する前に、該第1のノードから該第2のノードへの第3のデータパケットの伝送を開始することであって、該第3のデータパケットの伝送は、該第1のデータパケットに対応する任意の受信確認情報が、該第2のノードから受信される前に開始される、ことと、
    該第2のノードにおいて、該第3のデータパケットを受信することであって、該第3のデータパケットの受信は、有限の長さの時間を要する、ことと、
    該第2のデータパケットの伝送が終了した後、該第3のデータパケットの受信が開始した後、および該第3のデータパケットの受信が終了する前に、該第2のノードから該第1のノードへの第4のデータパケットの伝送を開始することであって、該第4のデータパケットの伝送は、該第2のデータパケットに対応する任意の受信確認情報が、該第1のノードから受信される前に開始され、該第4のデータパケットは、該第2のノードによって該第1のデータパケットが正しく受信されたか否かを示す受信確認情報を含んでおり、該第1のデータパケットの伝送および該第4のデータパケットの伝送は、該第1のデータパケットの伝送の実質的に所定の長さの時間の後に、該第4のデータパケットが伝送されるように連動している、ことと、
    該第1のノードにおいて、該第4のパケットを受信することと、
    該第1のノードにおいて、該第1のデータパケットが正しく受信されたか否かを示す受信確認情報を処理することであって、該第1のノードは、該第1のデータパケットが該第2のノードにおいて正しく受信されない場合に、該第1のデータパケットを再伝送する、ことと
    を含む、方法。
  13. コンピュータ読取り可能な媒体に明確に具体化されたコンピュータプログラム製品であって、該コンピュータプログラム製品は、
    第1のノードから第2のノードに第1のデータパケットを伝送することであって、該第1のデータパケットは、該第1のノードからの非充填データを含む第1のデータフィールドを含んでいる、ことと、
    該第1のデータパケットの伝送の後に、第2のデータパケットを該第1のノードから該第2のノードに伝送することであって、該第2のデータパケットの伝送は、該第1のデータパケットに対応する任意の受信確認情報が該第2のノードから受信される前に開始される、ことと、
    該第1のノードにおいて第3のデータパケットを受信することであって、該第3のデータパケットは、該第2のノードから伝送され、該第3のデータパケットは、該第1のデータパケットが該第2のノードによって正しく受信されたか否かを示す受信確認情報を含んでおり、該第1のデータパケットの伝送および該第3のデータパケットの受信は、該第1のデータパケットの伝送の実質的に所定の長さの時間の後に、該第3のデータパケットが受信されるように連動している、ことと
    を含む動作をプログラム可能なプロセッサに実行させるように動作することが可能な命令を備えている、コンピュータプログラム製品。
  14. 前記第2のデータパケットは、該第2のデータパケットの第2のデータフィールドに配置する任意の非充填データを前記第1のノードが有しているか否かに関わらず伝送される、請求項13に記載のコンピュータプログラム製品。
  15. 前記第1、第2、および第3のデータパケットの各々は、それぞれのフロー制御情報を含んでおり、該第1および第2のデータパケットにおける該フロー制御情報は、前記第1のノードに関係しており、該第3のデータパケットにおける該フロー制御情報は、前記第2のノードに関係している、請求項13に記載のコンピュータプログラム製品。
  16. 前記フロー制御情報は、複数のチャネルに対する別個のフロー制御情報を含む、請求項15に記載のコンピュータプログラム製品。
  17. 前記第1のデータパケットは、複数のチャネルのうちのどのチャネルに前記非充填データが伝送されているかを示すヘッダ情報を含んでいる、請求項13に記載のコンピュータプログラム製品。
  18. 前記第1および第2のデータパケットの各々は、前記第1のノードの欠陥状態の表示を含んでおり、
    前記第3のデータパケットは、前記第2のノードの欠陥状態の表示を含んでいる、請求項13に記載のコンピュータプログラム製品。
  19. 前記第3のデータパケットが受信される前に、前記第1のノードにおいて第5のデータパケットを受信することであって、該第5のデータパケットは、該第3のデータパケットの前に、前記第2のノードから伝送され、該第5のデータパケットは、特定のデータパケットが該第2のノードによって正しく受信されたか否かを示す受信確認情報を含んでいない、こと
    を含む動作を実行するように動作することが可能な命令をさらに備えている、請求項13に記載のコンピュータプログラム製品。
  20. コンピュータ読取り可能な媒体に明確に具体化されたコンピュータプログラム製品であって、該コンピュータプログラム製品は、
    第1のノードと第2のノードとの間でデータパケットを同期的に通信すること
    を含む動作をプログラム可能なプロセッサに実行させるように動作することが可能な命令を備えており、該同期的に通信することは、
    該第2のノードによる受信の受信確認を待機することなしに、該第1のノードからデータパケットを伝送することと、
    該第1のノードにおいて、該第2のノードから所定のデータパケットの受信の受信確認を引き続き受信することであって、該受信確認は、所定のデータパケットの伝送後、実質的に所定の時間に受信され、該受信確認は、改悪されていない所定のデータパケットを該第2のノードが受信したことを示している、ことと
    を含む、コンピュータプログラム製品。
JP2006337855A 2005-12-22 2006-12-15 同期データ通信 Withdrawn JP2007174646A (ja)

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
US75399105P 2005-12-22 2005-12-22

Publications (1)

Publication Number Publication Date
JP2007174646A true JP2007174646A (ja) 2007-07-05

Family

ID=38300539

Family Applications (3)

Application Number Title Priority Date Filing Date
JP2006333845A Withdrawn JP2007174644A (ja) 2005-12-22 2006-12-11 同期データ通信
JP2006337855A Withdrawn JP2007174646A (ja) 2005-12-22 2006-12-15 同期データ通信
JP2006342980A Withdrawn JP2007174666A (ja) 2005-12-22 2006-12-20 マルチ優先度メッセージング

Family Applications Before (1)

Application Number Title Priority Date Filing Date
JP2006333845A Withdrawn JP2007174644A (ja) 2005-12-22 2006-12-11 同期データ通信

Family Applications After (1)

Application Number Title Priority Date Filing Date
JP2006342980A Withdrawn JP2007174666A (ja) 2005-12-22 2006-12-20 マルチ優先度メッセージング

Country Status (2)

Country Link
JP (3) JP2007174644A (ja)
CN (3) CN101432629B (ja)

Families Citing this family (19)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
ES2590148T3 (es) 2012-03-02 2016-11-18 Lsis Co., Ltd. Dispositivo de comunicación y procedimiento de comunicación
CN105431103B (zh) * 2013-08-09 2018-08-17 直观外科手术操作公司 具有用于控制容纳在远侧的多个马达的远程电流控制器的医疗机器人系统
US10616080B2 (en) * 2014-11-26 2020-04-07 Fanuc America Corporation System for diagnosis of robot state
CN104951373B (zh) * 2015-05-28 2018-11-27 浙江元亨通信技术股份有限公司 调度系统的消息队列处理方法
JP6980689B2 (ja) * 2016-03-31 2021-12-15 コーニンクレッカ フィリップス エヌ ヴェKoninklijke Philips N.V. 撮像システム及び撮像システムの複数のノード間における通信のための通信プラットフォーム
CN106095717B (zh) * 2016-06-27 2019-09-17 哈尔滨明快机电科技有限公司 一种动态延迟补偿方法及装置
CN106502950B (zh) * 2016-09-30 2019-10-01 株洲太昌电子信息技术股份有限公司 一种通过串口传输文件的方法及系统
US10237885B2 (en) * 2017-05-01 2019-03-19 Bae Systems Information And Electronic Systems Integration Inc. Multiple access wireless network with low latency subnet
US10728912B2 (en) * 2017-09-15 2020-07-28 Qualcomm Incorporated System and method of modes for data transmission
US10624707B2 (en) * 2017-09-18 2020-04-21 Verb Surgical Inc. Robotic surgical system and method for communicating synchronous and asynchronous information to and from nodes of a robotic arm
US10892995B2 (en) * 2017-12-28 2021-01-12 Ethicon Llc Surgical network determination of prioritization of communication, interaction, or processing based on system or device needs
US11923084B2 (en) 2018-09-07 2024-03-05 Cilag Gmbh International First and second communication protocol arrangement for driving primary and secondary devices through a single port
US20200078117A1 (en) 2018-09-07 2020-03-12 Ethicon Llc Energy module for drivig multiple energy modalities through a port
US11318618B2 (en) 2019-04-05 2022-05-03 Verb Surgical Inc. Robotic surgical system and method for handling real-time and non-real-time traffic
US11980411B2 (en) 2021-03-30 2024-05-14 Cilag Gmbh International Header for modular energy system
US11963727B2 (en) 2021-03-30 2024-04-23 Cilag Gmbh International Method for system architecture for modular energy system
US11950860B2 (en) 2021-03-30 2024-04-09 Cilag Gmbh International User interface mitigation techniques for modular energy systems
US11978554B2 (en) 2021-03-30 2024-05-07 Cilag Gmbh International Radio frequency identification token for wireless surgical instruments
CN114872052B (zh) * 2022-06-06 2023-01-06 吉林农业科技学院 一种远程自动控制智能工厂机械臂的方法及系统

Family Cites Families (9)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
AT405588B (de) * 1995-06-26 1999-09-27 Ericsson Schrack Aktiengesells Verfahren zur wiederholung fehlerhaft übertragener daten
US6182120B1 (en) * 1997-09-30 2001-01-30 International Business Machines Corporation Method and system for scheduling queued messages based on queue delay and queue priority
WO2000013364A1 (en) * 1998-08-26 2000-03-09 Nokia Networks Oy Bidirectional arq apparatus and method
CN1134135C (zh) * 2000-11-22 2004-01-07 深圳市中兴通讯股份有限公司 一种应用于双网容错系统的通讯方法
CN100479418C (zh) * 2001-03-27 2009-04-15 信息产业部武汉邮电科学研究院 物理层与网络层设备之间的数据传输装置和方法
US6728599B2 (en) * 2001-09-07 2004-04-27 Computer Motion, Inc. Modularity system for computer assisted surgery
JP3471785B1 (ja) * 2002-07-31 2003-12-02 松下電器産業株式会社 通信装置及びデータの再送制御方法
CN1249942C (zh) * 2003-05-13 2006-04-05 武汉汉网高技术有限公司 正交频分复用系统中的随机接入方法
CN100484136C (zh) * 2003-10-27 2009-04-29 英特尔公司 网络协议引擎

Also Published As

Publication number Publication date
CN101346915A (zh) 2009-01-14
JP2007174666A (ja) 2007-07-05
CN101432629A (zh) 2009-05-13
CN101366010A (zh) 2009-02-11
JP2007174644A (ja) 2007-07-05
CN101432629B (zh) 2013-04-03
CN101366010B (zh) 2012-09-19
CN101346915B (zh) 2012-07-18

Similar Documents

Publication Publication Date Title
US8838270B2 (en) Synchronous data communication
US7756036B2 (en) Synchronous data communication
JP2007174646A (ja) 同期データ通信
KR101325022B1 (ko) 다중 우선순위 메시징
JP4985565B2 (ja) 送受信回路、受信回路及び送受信回路の制御方法
US20080195912A1 (en) Method of communicatoin
JP4807828B2 (ja) ブロードバンド・エンジンのためのエンベロープ・パケット・アーキテクチュア
CN114337938B (zh) 一种数据传输方法、数据重传方法、装置和相关设备
JP5857568B2 (ja) 情報処理システム、受信装置、及び情報処理方法
WO2010027064A1 (ja) データ伝送方法、データ伝送システム、データ送信装置、データ受信装置、及び制御プログラム
JP2008205797A (ja) データ通信装置およびデータ通信システム

Legal Events

Date Code Title Description
A300 Application deemed to be withdrawn because no request for examination was validly filed

Free format text: JAPANESE INTERMEDIATE CODE: A300

Effective date: 20100302