JP4731643B2 - スクリプト作成システム - Google Patents
スクリプト作成システム Download PDFInfo
- Publication number
- JP4731643B2 JP4731643B2 JP21747797A JP21747797A JP4731643B2 JP 4731643 B2 JP4731643 B2 JP 4731643B2 JP 21747797 A JP21747797 A JP 21747797A JP 21747797 A JP21747797 A JP 21747797A JP 4731643 B2 JP4731643 B2 JP 4731643B2
- Authority
- JP
- Japan
- Prior art keywords
- script
- code
- widget
- subsystem
- user
- 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 - Fee Related
Links
Images
Classifications
-
- G—PHYSICS
- G01—MEASURING; TESTING
- G01S—RADIO DIRECTION-FINDING; RADIO NAVIGATION; DETERMINING DISTANCE OR VELOCITY BY USE OF RADIO WAVES; LOCATING OR PRESENCE-DETECTING BY USE OF THE REFLECTION OR RERADIATION OF RADIO WAVES; ANALOGOUS ARRANGEMENTS USING OTHER WAVES
- G01S7/00—Details of systems according to groups G01S13/00, G01S15/00, G01S17/00
- G01S7/52—Details of systems according to groups G01S13/00, G01S15/00, G01S17/00 of systems according to group G01S15/00
- G01S7/52017—Details of systems according to groups G01S13/00, G01S15/00, G01S17/00 of systems according to group G01S15/00 particularly adapted to short-range imaging
- G01S7/52098—Details of systems according to groups G01S13/00, G01S15/00, G01S17/00 of systems according to group G01S15/00 particularly adapted to short-range imaging related to workflow protocols
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
- G06F3/01—Input arrangements or combined input and output arrangements for interaction between user and computer
- G06F3/02—Input arrangements using manually operated switches, e.g. using keyboards or dials
- G06F3/023—Arrangements for converting discrete items of information into a coded form, e.g. arrangements for interpreting keyboard generated codes as alphanumeric codes, operand codes or instruction codes
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/44—Arrangements for executing specific programs
- G06F9/455—Emulation; Interpretation; Software simulation, e.g. virtualisation or emulation of application or operating system execution engines
- G06F9/45504—Abstract machines for programme code execution, e.g. Java virtual machine [JVM], interpreters, emulators
- G06F9/45508—Runtime interpretation or emulation, e g. emulator loops, bytecode interpretation
- G06F9/45512—Command shells
-
- G—PHYSICS
- G16—INFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR SPECIFIC APPLICATION FIELDS
- G16H—HEALTHCARE INFORMATICS, i.e. INFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR THE HANDLING OR PROCESSING OF MEDICAL OR HEALTHCARE DATA
- G16H40/00—ICT specially adapted for the management or administration of healthcare resources or facilities; ICT specially adapted for the management or operation of medical equipment or devices
- G16H40/40—ICT specially adapted for the management or administration of healthcare resources or facilities; ICT specially adapted for the management or operation of medical equipment or devices for the management of medical equipment or devices, e.g. scheduling maintenance or upgrades
-
- G—PHYSICS
- G16—INFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR SPECIFIC APPLICATION FIELDS
- G16Z—INFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR SPECIFIC APPLICATION FIELDS, NOT OTHERWISE PROVIDED FOR
- G16Z99/00—Subject matter not provided for in other main groups of this subclass
Description
【発明の分野】
本発明は全般的に医療用イメージング方式に関し、更に具体的に云えば、プログラム可能なイメージング・システムに関する。
【0002】
【発明の背景】
一般的に医療用イメージング・システムは、患者の身体の一部分の画像を作成して医者が観察できるようにするために利用されている。モダリティと呼ばれる異なるイメージング技術を使って、患者の身体の複数の部分をイメージングすることが出来る。モダリティの例としては、コンピュータ断層撮影(CT)イメージング、磁気共鳴(MR)イメージング、超音波イメージング、ポジトロン・エミッション断層撮影(PET)イメージング、及び核イメージングがある。
【0003】
医療用の画像の作成、処理及び表示に関連して、医療用イメージング・アプリケーションの開発には、一般的に、かなりのソフトウェア開発の努力を必要とする。この開発は、グラフィック・ユーザ・インタフェース(GUI)を基本とする医療用イメージングのアプリケーションを開発するのに特殊なソフトウェア技術が必要とされるので、高度に熟練したソフトウェア実務者によって行われるのが普通である。しかし、ソフトウェア技術者は、その知識の領域が限られている。実際にソフトウェア・アプリケーションを使う臨床医は、アプリケーションを開発するのに必要なソフトウェア技術に熟練していないのが普通である。臨床医がイメージング・アプリケーションを開発することが出来るように高度に使いやすいイメージング・システムを提供することが望ましい。
【0004】
公知の「プログラム可能な(programmable)」システムは、臨床医がカスタマイズされたイメージング・アプリケーションを作成することが出来るようにしている。例えば、最も簡単な形式のカスタマイズ化は、特定の医者に対する表示スクリーン又はその他の条件のカスタマイズ化である。更に複雑なカスタマイズ化は、例えば研究機関では必要になる。
【0005】
しかし、既知のプログラム可能なイメージング・システムは多数の欠点がある。例えば、一つの既知のプログラム可能なシステムは、新しいGUIエレメントを作成/カスタマイズする能力がない。更に、こういうシステムは基本システムに統合されておらず、その結果、視覚上、機能的及び使い易さの点で問題がある。更に、経験のあるプログラマしかシステムに機能を追加することが出来ない。
【0006】
次に、既知のプログラム可能なイメージング・システムの別の欠点を説明する。これらの欠点は、一般的にスクリプトの作成と実行、非同期的な実行、及び観察テンプレート編集機能に関係するものである。
【0007】
1.スクリプトの作成と実行典型的には、画像を見る医者が所望のフォーマットで画像データを見ることが出来るように、医療用の画像の表示及び処理シーケンスを制御する為にスクリプトが利用される。例えば、特定の医者は、特定の器官を見る時、特定の系列(シーケンス)のビュー(view)が表示されることを好むことがある。スクリプトは、画像の表示を制御して所望の系列のビューが作成されて表示されるように、作成することが出来る。
【0008】
グラフィック・ユーザ・インターフェース(GUI)ベースのソフトウェア・アプリケーションから十分に機能的で使いやすいスクリプトを作成することは困難である。典型的には、ボタンのクリックのようなGUIイベントを記録し、同じアプリケーション内でこのイベントを再現することによってスクリプトが作成される。しかし、多くの場合、異なる処理環境のコンテキストで使うことの出来る出力スクリプトを作成することが望ましい。こういう場合、単なる一系列のGUIイベントではなく、ユーザが行った動作のセマンティクス(semantics)を捕捉しなければならない。
【0009】
種々のレベルのGUIイベントを記録して再生することが出来るアプリケーションの例は多くある。このような一つの既知のプログラムは、マウスの動き、ボタンを押したこと並びにキーボードのクリックを記録し、これらのイベントを再現する。しかし、GUIに対する極くわずかな変更でも、その変更を捕捉するにはイベントをもう一度記録することが必要になる。
【0010】
別の既知のアプリケーションは、単にマウス及びキーボードの動作ではなく、作動された(押された)GUIウィジット(ボタン、スライダ等)を記録する。このプログラムは、GUIの変更がわずかな場合、問題を軽減するが、それでも、もとのアプリケーションで作成されたスクリプトを再生することを必要とする。即ち、このプログラムはアプリケーションを記録し、同じアプリケーションを使ってそれを再生することが出来るようにするだけである。作成されたスクリプトは、アプリケーションの外部で使うように設計されていない。更に、作成された出力スクリプトのシンタックス(syntax)が完全に予じめ定められていて、ユーザが構成し得るものではない。
【0011】
2.非同期的な実行既知の医療用イメージングシステムはクライアント/サーバ形アーキテクチュアを持っている。このアーキテクチュアの主な利点は、アプリケーションがほとんど処理をしないので、アプリケーションのプロセスがユーザの面倒を見る状態にとどまることが出来ることである。大抵の処理はサーバによって処理される。このサーバは、特定のサービスを行う「専門家」であり、実際に、特定のタスクに対して最適にした専用のハードウェアで動作することがある。この専門化の良い例が、共通の画像処理動作をハードウェアで加速する処理サーバである。ネットワークに分布したリソースにアクセスする能力が、クライアント/サーバ形アーキテクチュアの主な利点である。
【0012】
クライアント/サーバ形アーキテクチュアに於けるタスクの実行について云うと、アプリケーションがあるサービスに対する要請(リクエスト)を出す。この要請を処理するサーバは、ローカル・エリア・ネットワークのどこにあっても良い。アプリケーションはその結果をユーザに報告する前に、動作が完了するのを待たなければならない。アプリケーションが待たなければならない時間の長さは、サーバの速度を含めた多くの因子に関係する。対話状態を維持する為には、アプリケーションは明け渡しをしなければならないが、これは典型的には、アプリケーションが他のユーザの要請に応答することが出来るように、実行スレッド(thread)をアイドル状態に戻すことによって行われる。この明け渡す機能が対話型のアプリケーションの基本である。前に待ち行列に入れていた要請からの返答が到着した時、アプリケーションはアプリケーションの処理コンテキストをこの要請以前の状態に回復し、動作の結果を提示しなければならない。このプロセスは、普通、非同期動作と呼ばれている。
【0013】
経験によると、要請−明け渡し−返答形のパラダイムを実施すると、プログラミングにかなりの昏迷が入り込むことが分かった。これは、1個の動作を多数の実行スレッドに分割しなければならないし、状態またはコンテキスト情報を、要請側を返答側に拘束するように管理しなければならないし、また多数の対話型の非同期的な実行スレッドの為に、微妙な診断の難しいタイミングに関係するエラーがコードに入り込むことがあるからである。その結果得られるコードは維持するのが難しい。こういう因子により、こういう環境でのプログラマの生産性が大幅に低下している。
【0014】
それに、非同期的な実行のアプリケーション・コードは複雑であって、こういう環境でコードを開発するには、コンピュータ・プログラミングの高度の熟練が要求される。例えば、上に述べた要請−明け渡し−返答形の開発パラダイムでは、経験のあるソフトウェア技術者に対して、典型的には6週間ないし8週間の訓練期間が必要である。この訓練期間の多くは、非同期的なソフトウェア・プログラミングの細かい点を理解することに費やされる。更に、非同期的なプログラミングの複雑さの為、これは、普通はソフトウェア技術者ではない大抵の最終ユーザにとって不適当な方式である。クライアント/サーバ形アプリケーションの開発者は、大部分、クライアント/サーバ形アプリケーションの融通性並びに高い対話能力の代償として、要請−明け渡し−返答形のプログラム・パラダイムの開発の効率の悪さを受け入れている。
【0015】
更に、非同期的な動作のある欠点を避けようとして、データベースの機能が同期的に動作する方式が存在する。例えば、既知の一つの方式では、プログラマが異常に長い動作を検出し、是正措置をとる。こういう動作を実施する為に使われる機構がポーリング機構であり、待ち段階の間、GUIを凍結する。即ち、GUIは真の明け渡しをしない。応答の待ち時間を非常に短くしなければならない医療用イメージング及び実時間制御のアプリケーションでは、オペレータが長いトランザクションの間に緊急の状況に応答しなければならないことがあるから、こういう形式の機構は受け入れることが出来ないことがある。この方式の別の欠点は、待ち期間の間、長い動作を取り消すことが出来ないことである。要請−明け渡し−返答形のパラダイムのコードを入れる煩わしさを無くすと共にその利点を生かしながら、長いトランザクションの間でも、アプリケーションの対話能力を温存するシステムを提供することが望ましい。
【0016】
3.オーバーラップの検出と補正医療用イメージング・アプリケーションを開発する時、頻繁に起こるのは観察テンプレートを構成することである。観察テンプレートは、医療用診断情報を見直すことに関連して、画像、曲線、テキスト及びその他の患者情報をグラフで提示することである。観察テンプレートを構成する時、典型的には矩形セルが構成され、スクリーン上のセルの配置を選び、これらのセルに対する属性の明細を定める。セルは、画像、曲線、テキスト並びに診断過程に関連するその他の情報を含むことが出来る。
【0017】
患者情報を見る多くの医者にとって、情報の提示及びフォーマットは非常に重要である。その為、多くの医者は、自分の個人的な診断の必要に合う個人向けの観察テンプレートを要求する。最終ユーザが観察テンプレートをカスタマイズできるようにする為には、イメージング・システムは、観察テンプレートを構成し又は変更する容易な方法を提供しなければならない。更に、観察テンプレート・エディタは特定のタスクに対して最適にすることが好ましい。
【0018】
観察テンプレートを構成する既知の1つのシステムは、テンプレートを作る為にポイント・アンド・クリック形のインターフェースとなるグラフ式観察テンプレート・エディタを使っている。グラフ式エディタは、観察テンプレートを構成する為の最終ユーザにとって容易な方法であることが分かっている。
【0019】
しかし、既知の観察テンプレート・エディタの1つの欠点は、こういうシステムはユーザがセルのオーバーラップを補正することを必要とすることである。具体的に云うと、セルはタイル状になっていて、オーバーラップがあると重要な診断情報が隠れてしまうので、決してオーバーラップを生じることがない。従って、ユーザは、マウス又はプロパティ・エディタを使って、辛抱強く、細心にセルを位置ぎめしなければならない。このタスクを助ける為、ある観察テンプレート・エディタは、更に正確なアラインメントを行うことが出来るようにするズーム・モードのようなツールを含んでいる。他の既知のシステムは、タイリング(tiling)ポストプロセッサを使い、それがセルを最小の幾何学的な形に詰め込む。医療用イメージングの観察テンプレートを構成する場合、こういうツールは実行する時に時間がかかりすぎるか、タイリング・ポストプロセッサの場合のように、ユーザに代ってあまりにも多くのことをする為に、融通性が欠ける。手作業のセル・アラインメント・タスクを加速することにより、使い易さを高めることが出来るような自動的なオーバーラップ検出及び補正アルゴリズムを提供することが好ましい。
【0020】
既知のプログラム可能なシステムに関連する上に述べた欠点が、臨床医が比較的容易に且つ素早くイメージング・アプリケーションを開発することが出来るように、ユーザにとって極めて親しみやすいプログラム可能なシステムによって解決されることが好ましい。更に、スクリプトについて云うと、このスクリプトは、環境の如何に関わらず、余分のかなりの努力及び費用をかけずに、医者の希望に従って、画像及びデータを観察の為に表示することが出来るように、多くの異なる環境で使うことが出来ることが好ましい。このスクリプトの作成が簡単であって、対話型であることも好ましい。更に、前に述べたように、要請−明け渡し−返答形のパラダイムのコードを入力する煩わしさを避けると共に、その利点を生かしながら、長いトランザクションの間でも、アプリケーションの対話能力を温存するシステムを提供することが望ましい。また、観察テンプレートを作成するため、手作業のセル・アラインメント・タスクを加速することにより、使い易さを高めた自動的なオーバーラップ検出及び補正アルゴリズムを提供することが望ましい。
【0021】
【発明の概要】
上記並びにその他の目的が、臨床医にとってシステムの使い易さを高める為に、アルゴリズムを取り入れたプログラム可能な医療用イメージング・システムによって達成することが出来る。プログラム可能な点について云うと、本発明の一面では、スクリプトを作成する為に使うことの出来る学習モードを含むプログラム可能なシステムを提供する。学習モードでは、ユーザが一連の動作を行い、それらの動作を後で再現するように保存することが出来る。学習モードは、ユーザがプログラミングの努力を伴わずに新しい機能を開発できるようにするので、新しいユーザ・プロトコルを定義する為の直感的な出発点になる。
【0022】
更に具体的に学習モードについて云うと、システムは、システム構成ファイル、テーブル・ローダ及び自動インストーラを含む初期設定/装備サブシステムを含む。動作について説明すると、テーブル・ローダがシステム構成ファイルを読取って、システム構成ファイルから読取った情報を使って、マスター・テーブルを初期設定する。自動インストーラが、マスター・テーブルに記憶されている「ウィジット(wedget)ネーム」を使って、グラフィック・ユーザ・インターフェース(GUI)アプリケーションから関連するウィジットを見つけ、そのウィジットIDをマスター・テーブルに記憶する。
【0023】
システムGUIで作業するユーザが、一連のイベントを入力し、それがGUIイベント・ハンドラー・システムによって記録される。コード作成器が、特定された各々のGUI動作に対応するスクリプト指令を出力する。コード圧縮システムが、現在の指令及び前の指令からの出力変数を抽出し、出力変数を圧縮コードにある1及び0と比較する。マスクされていないオブジェクト・ネームの副次記号表現が同じであれば、出力は前の出力の代わりであると考えられる。システムが前の出力を追跡し、新しい出力が代わりであると考えられる場合、前の出力を削除する。一般的に、コード圧縮システムからの出力が出力スクリプトと呼ばれる。
【0024】
上に述べたシステムを使って作成された出力スクリプトは、他の処理環境に簡単に転送可能である。更に、このシステムは、既知のプログラム可能なシステムに比べて、比較的使いやすく、ユーザにとって極めて親しみやすい。更に、このシステムは、単に動作自体を記録するのではなく、動作の意図を捕捉する形で、ユーザ動作(例えば、キーのクリック及びマウスの動き)のシーケンスを出力指令に解釈する。例えば、2つの像を付け加える為、GUIは、ユーザが付け加える画像を選び、加算動作を選び、選ばれた動作を印加するなどという一連の動作を行うことを必要とする。本発明のシステムでは、出力は、個別の画像を選択するプロセスよりもむしろ、ユーザが意図する画像を付け加える指令を表わす。
【0025】
本発明の別の一面では、下位の非同期的なアーキテクチュアに対する非ブロッキング同期インターフェイスを構成するアルゴリズムを提供する。全般的に云うと、このアルゴリズムはアプリケーションのクライアント/サーバ部分を同期的な開発の環境から切り離す。このアルゴリズムを使うと、プログラマーは、非同期的なプログラミング技術に頼らずに、非ブロッキング型の高度に対話型のクライアント/サーバ形アプリケーションを開発することが出来る。
【0026】
その結果得られるコードは同期的で、非常に読取りやすく、こじんまりしており、クライアント/サーバ形アーキテクチュアのプログラミングに習熟していない実務家によって開発することが出来る。更に、このアルゴリズムは、多重実行スレッドの本質的な支援を持っている又は持っていないオペレーティング・システムで実施することが出来る。
【0027】
本発明の更に別の一面では、オーバーラップ検出及び補正アルゴリズムを提供する。一形式では、このアルゴリズムは、観察テンプレートを作る為の観察テンプレート・エディタに統合されている。1実施例では、オーバーラップ検出及び補正アルゴリズムは、1又は2境界矩形セル・オーバーラップ検出及び補正アルゴリズムである。このアルゴリズムは非パッキング型であって、その為、ユーザのアラインメント動作の意図を正確に実行し、セル・アラインメント・タスクを加速するという重要な利点をもたらす。
【0028】
上に述べたプログラム可能なシステムは、ユーザに極めて親しみやすく、臨床医はこのシステムを使って、イメージング・アプリケーションを比較的容易に且つ素早く開発することが出来ると考えられる。更に、このシステムを使って作成されたスクリプトは、多くの異なる環境で使うように容易に移すことが出来、この為、環境の如何に関わらず、余分のかなりの努力及び費用を伴わずに、医者の希望に従って、画像及びデータを観察の為に表示することが出来る。更に、クライアント/サーバ形アーキテクチュアを利用するが、要請−明け渡し−返答形のパラダイムのコードを入力するという煩わしさを避けながら、長いトランザクションの間でも、システムの対話能力を温存する。更に、観察テンプレートの作成について云うと、自動オーバーラップ検出及び補正は、手作業のセル・アラインメント・タスクを加速することにより、使い易さを高めることが出来る。
【0029】
本発明の一態様によれば、グラフィック・ユーザ・インターフェース、グラフィック・ユーザ・インターフェース・イベント・ハンドラー・システム、メモリ装置及び処理装置を持つコンピュータを含み、前記処理装置が前記グラフィック・ユーザ・インターフェース、グラフィック・ユーザ・インターフェース・イベント・ハンドラー・システム及びメモリ装置に結合されている医療用イメージング・システムに対するスクリプト作成システムが提供される。該スクリプト作成システムは、前記グラフィック・ユーザ・インターフェース・イベント・ハンドラー・システム及び前記メモリ装置に結合されていて、前記メモリ装置に記憶されているシステム構成ファイルからのデータを使ってマスタ・テーブルを初期設定するように構成された初期設定サブシステムであって、前記システム構成ファイルが装備に関連するデータを持っている初期設定サブシステムと、前記グラフィック・ユーザ・インタフェース・イベント・ハンドラー・システムに結合されていて、前記イベント・ハンドラー・システムによって記録された各々のイベントに対応するスクリプト指令を作成するように構成されたコード作成サブシステムとを有する。前記システム構成ファイルは、装備される指令のオブジェクト・ネーム、装備されるウィジットのウィジット・ネーム、及びオブジェクトの種類の明細を有している。前記オブジェクトの種類の明細は、様式(MODAL)、デストラクタ(DESTRUCTOR)、コンストラクタ(CONSTRUCTOR)及びノーマル(NORMAL)を含む複数の異なるオブジェクトの種類を有する。前記初期設定サブシステムは、前記システム構成ファイルを読取って前記マスター・テーブルを初期設定するテーブル・ローダを含む。前記初期設定サブシステムは、更に、前記マスター・テーブルに記憶されているウィジット・ネームを前記グラフィック・ユーザ・インターフェースからのウィジットと関連させ、該関連するウィジットに対するウィジット識別子を前記マスター・テーブルに記憶する自動インストーラを含む。前記メモリ装置にはウィジット階層が記憶されており、前記自動インストーラが該ウィジット階層を探索して前記ウィジット・ネームを前記ウィジットに関連させる。前記コード作成サブシステムは、前記イベント・ハンドラー・システムによって記録された各々のイベントに対応するスクリプト指令を出力するように構成されたコード作成器を含む。前記コード作成サブシステムは、前記スクリプト指令を出力するために、前記イベント・ハンドラー・システムによって記録されたイベントに対応するオブジェクト・ネームを評価して、該オブジェクト・ネームが装備されているウィジットであるかどうか判定するように構成されている。前記コード作成サブシステムは、更に、前記コード作成器に結合されていて、前記コード作成器から出力されたスクリプト指令を受け取り、現在の指令及び前の指令からの出力変数を比較して、現在の指令が前の指令の代りであれば、前の指令を削除するように構成されているコード圧縮サブシステムを含んでいる。前記コード圧縮サブシステムは、前記コード作成器から出力されたスクリプト指令の圧縮されたものを作成するように構成されている。
【0030】
【発明の好ましい実施の形態】
本発明の一面は、システムの使い易さを高めるアルゴリズムを取り入れたプログラム可能な医療用イメージング・システムに関する。アルゴリズムは全般的に、学習モードのスクリプトの作成、同期動作、及び観察テンプレート・エディタに於けるオーバーラップ検出及び補正に関係する。重要なことは、本発明を多くの異なる医療イメージングモダリティで実施することが出来、何ら1つの特定の様式で実施する場合に制限されないことである。次に本発明の1実施態様のプログラム可能なシステムを説明する。更に、学習モード、同期動作並びにオーバーラップ検出及び補正ルーチンを説明する。
【0031】
[プログラム可能なシステムの説明]ここで説明するプログラム可能な医療用イメージング・システムは、例えば米国ウイスコンシン州、ブルックフィールド、スート100、ノース・パトリック・ブールバード250所在のヒューレット・パッカード・カンパニから商業的に入手し得る製品名「HP715/100UNIX」を基本としたワークステーションを含む多くのハードウェア・プラットフォームで実現することが出来る。1形式では、例として云うと、ルーチンは、米国ウイスコンシン州、ウォーキーシャ、ノース・グランドビュー・ブールバード3000所在のゼネラル・エレクトリック・カンパニ社GEメディカル・システムズ事業部から商業的に入手し得る「GENIE(登録商標)システム」の名前で知られいるような核イメージング・システムに統合して、それに関連して実施することが出来ると考えられている。もちろん、ルーチンは、核イメージング・システム以外のものを含む他の多くの医療用イメージング・システムに関連して、他の多くのプラットフォームで実施することが出来る。
【0032】
次に説明するのは、スクリプトの作成、並びにその他のプログラム能力に関係するタスクに対するツールを含む1実施態様のプログラム可能なシステムである。これらのツールは、ユーザ・ワークステーションで実現することが出来、後で説明するように、メニューを介してユーザがアクセス可能である。ツールの機能を理解しやすくする為、新しいアプリケーション、即ちスクリプトを開発するステップを下にまとめて示す。
【0033】
1.予め定めたプロトコル・ナビゲーション区域に所望のボタンを置く。
2.GUI上でアプリケーションの動作を実行することにより、コードを作成する。
3.必要であれば作成されたコードをカスタマイズする。
4.作成されたコードをボタンに付加する。
【0034】
プログラム能力に関するツールは、これらの4つの基本的な工程をポイント・アンド・クリック動作で達成出来るようにすることが好ましい。更に、簡単なアプリケーションでは、これらのツールは、プログラミングを必要としないようにし、更に複雑なアプリケーション並びに更に融通性を持たせる場合には、ビジュアル・ベーシック(Visual Basic)及びC言語を使って低レベルのプログラミングを行うことが出来るようにすることが好ましい。UNIXを基本としたシステムに対するビジュアル・ベーシック・コンパイラは、米国ニューヨーク州、ジェームスヴィル、ジェームスヴィル・ロード4933所在のサミット・ソフトウェア・カンパニから商業的に入手し得る。
【0035】
1実施態様では、特に前に述べたGENIEの環境で実施する場合、現存のGENIEプロトコルに従ってナビゲーションユーザ・インターフェース(UI)のモデルを定め、簡単なポイント・アンド・クリックによりボタン及びメニューの形の新しいナビゲーション要素を付け加える。ボタンの二重クリックにより、ユーザはそのボタンに挙動を持たせることが出来る。普通、挙動は結果スクリーンに表示すること、又は一連の処理動作を行い、その後にその結果を表示することである。
【0036】
図1は前掲のGENIEシステム用に構成した一例のユーザ・インターフェース100を示す。図1に示すように、ナビゲーション区域102が組み立てられつつある。2つのタブ104及び106が作られており、第1のタブ104が3つのボタン108、110及び112を含む。ナビゲーション区域102を組み立てる為の「ナビゲーション」メニュー項目114がメニュー116に設けられている。ユーザ・インターフェースはスクリプト・エディタ窓118をも含み、メニュー116はユーザが選ぶことの出来る種々の機能を示している。アクティブ・ヘルプ窓120も示されている。更にインターフェース100は、医療用の画像及びデータを表示する画像区域122をも含む。
【0037】
アプリケーションの挙動を特定しやすくするため、ポイント・アンド・クリック作成器、統合エディタ及び外部インタフェースが設けられる。ポイント・アンド・クリック・コード作成器は、ユーザ動作のセマンティクスを表すコードを作成する。統合エディタは、融通性を最大にする為に複合コードを書き込むことが出来るようにする為に設けられており、また統合エディタは、作成されたコードをカスタマイズする為に使うこともできる。この外部インターフェースは、例えば、画像処理機能又は外部データ収集装置のような外部機能を素早く利用出来るようにする。
【0038】
多数の部品をプログラム能力の環境内に統合して、臨床アプリケーションを開発する為のコヒーレンスの高いツールとする。これらの部品は、学習モード、スクリプト・エディタ、スクリプト・デバッガ及びスクリプト実行部を含む。学習モードは、ユーザが1つのシーケンスの動作を稽古し、後で再現されるようにそれらの動作を保存することが出来るようにする。更に、学習モードを使って、ユーザは動作のシーケンスを変更することが出来る。学習モードは、ユーザがプログラミングということをせずに、新しい機能を開発することが出来るようにするので、新しいユーザ・プロトコルを定義する為の直感的な出発点になる。学習モードは、動作とそれに対応するユーザ・プロトコル・スクリプトとの間のリンクとなるので、新米のユーザに対する良い学習ツールにもなる。1形式では、学習モードは次のことを行う。
【0039】
1.1組のユーザ動作を記録し、保存し、後でプロトコルを組み立てるのに使うことが出来る。
2.記録の間、動作のシーケンスからの作成されたテキストを表示することが出来る。
3.データ・ローディング及び保存動作が記録可能である。
4.観察テンプレートの記述が記録可能である。
5.画像及び曲線処理動作が記録可能である。
6.画像及び曲線統計結果が記録可能である。
【0040】
1例としての学習モード捕捉窓150が図2に示されており、この図には学習モードを動作させた結果が示されている。学習モードについて更に詳しいことは次の部分で説明する。
【0041】
再び図1を参照すると、ユーザがユーザ・プロトコルを編集することが出来るようにする為に、スクリプト・エディタ124が設けられている。エントリ並びにユーザ・プロトコルに対するテキストの変更を容易にする為、次に述べる特徴を設けることが出来る。下記の全ての特徴はマウス又はキーボードから作動することが出来る。
【0042】
1.「Edit(編集)→Cut(切り取り)」、「Edit(編集)→Copy(コピー)」、及び「Edit(編集)→Paste(貼り付け)」の為のテキスト編集能力。
2.順方向及び逆方向のテキスト・ストリングの探索。探索はいくつかのテキスト・ファイルに亘ることが出来る。
3.テキスト・ストリングの交換。
【0043】
適当なスクリプト・エディタは米国ニューヨーク州、ジェームスヴィル、ジェームスヴィル・ロード4933所在のサミット・ソフトウェア・カンパニから商業的に入手し得る。
【0044】
更に図1について説明すると、ユーザ・プロトコルの開発及びデバッギングを助ける為にスクリプト・デバッガ126が設けられている。スクリプト・デバッガ126は下記の作用を実行する。
【0045】
1.シンタックス検査の特徴が設けられる。エラーが存在する場合、正しくない行が強調され、カーソルがシンタックスとして正しくない要素の上に置かれる。更に、診断メッセージが表示される。
2.ユーザ・プロトコルは一度に1行実行することが出来る。
3.機能/手順に歩進することが出来、或いは機能/手順を1つのユニットとして実行することが出来る。
4.ブレーク点をユーザ・プロトコル内の任意の行にセットすることが出来る。ユーザ・プロトコルの実行はブレーク点で停止する。ブレーク点は取り除くことが出来る。
5.変数をデバッガ内にある間に検査し変更することが出来る。
【0046】
適当なスクリプト・デバッガが前に引用したサミット・ソフトウェア・カンパニから商業的に入手し得る。
【0047】
完全な又は部分的に完成したユーザ・プロトコルの実行128がスクリプト実行部によって行われる。プロトコルは、そのプロトコルの断片を開発し、次いで徐々に機能を埋めることによって、増分的に試験することが出来る。スクリプト実行部は、下記の特徴を用いてこの能力を発揮する。
【0048】
1.プロトコルは、完了するまで又は割込みに出会うまで実行を続ける。
2.プロトコルを実行するとき、ユーザはスクリプト実行部から全ての画像表示、対話、メニュー及びツールを利用し得る。本質的にはプロトコルは、ユーザが実際のプロトコルを始動させた場合と同様に実行される。スクリーン画像区域全体の代わりに、縮尺された画像区域122が表示されることに注意されたい。
3.ユーザ・プロトコルは休止ボタンを使うことにより、任意の点で中断可能である。再開した時、ユーザ・プロトコルを休止した点から実行が続けられる。
4.ユーザ・プロトコルは、停止ボタンを使って、任意の時に中止することが出来る。
5.全ての予め定められた機能ライブラリ及びユーザによって定められた機能ライブラリがスクリプト実行部で利用出来なければならない。
6.多重プロトコルは同時に実行することが出来ると共に対話状態に留まることが出来る。これは、全てのプロトコルが或るCPU時間を受け取ることを保証する時間スライス機構によって達成される。
【0049】
新しいプロトコルの作成について云うと、ユーザは現存のプロトコルを変更し、変更したプロトコルを新しいプロトコルとして保存することが出来る。この代わりに、ユーザはスクラッチから出発することが出来る。ユーザが現存のプロトコルを削除したいと思うことも考えられる。こういう活動が一般的にプロトコル・マネージメントと呼ばれる。1実施態様では、全てGUI100からアクセス可能である下記の特徴がプロトコルを管理するのに利用することが出来る。
【0050】
1.製造業者により提供されたプロトコルをコピーすることが出来、そのコピーは「File(ファイル)→Save As(そのまま保存)」の特徴(130)を使って変更することが出来る。
2.現存のプロトコルを見ることが出来る。即ちユーザにはソース・スクリプトが常に利用出来る。
3.ユーザは「File(ファイル)ファイル→New(新)」(130)によりスクラッチから新しいユーザ・プロトコルを作成することが出来る。
4.「File(ファイル)→Save(保存)」(130)により現存のプロトコルを変更することが出来る。
5.「File(ファイル)→Delete(削除)」(130)により現存のプロトコルを削除することが出来る。
【0051】
非常に使いやすいシステムには、そのシステム内の全てのアプリケーションが従う「ルック・アンド・フィール(look and feel)」がある。同様に前掲のGENIEシステムでは、プロトコルに対しルック・アンド・フィールが設定されている。1実施態様では、ナビゲーションGUI組立て部114を設けて、アプリケーションを作成するタスクを簡単にする。ナビゲーションGUI組立て部114は下記のことをする。
【0052】
1.ポイント・アンド・クリック・インターフェースを使って、タブ、ボタン及びメニューの項目を作成することが出来る。プログラミングは全く必要とされない。
2.ナビゲーションGUI組立て部(ナビゲーションGUIビルダ)の全ての要素(エレメント)に対してプロパティ・エディタを設ける。プロパティは、「動作(action)」手順の明細並びに要素の可視的な性質を含む。
3.完成されたナビゲーションの記述がプロトコルと共に保存される。プロトコルを実行するとき、動作プロパティが呼び出される。
【0053】
1実施態様では、オンライン・ハイパーテキスト・ヘルプ・システム120を含む多数のツールを設ける。ヘルプ・システム120は、プログラム能力の環境の全ての要素の利用に対してヘルプを提供する。この全般的なヘルプの他に、ビジュアル・ベーシック言語の包括的なヘルプも設けてある。言語に対する全ての新しい拡張に対してヘルプ・ファイルも設けてある。適当なハイパーテキスト・ヘルプ・システムが、米国コネティカット州、リッジフィールド、イーサン・アレン・ハイウェイ241所在のブリストル・テクノロジー・インコーポレーテッドから商業的に入手し得る。
【0054】
ヘルプ・システムのスクリーンを通じてスクリプトを容易に作成することが出来る。具体的に云うと、ユーザはヘルプ・スクリーンを呼び出し、作成しようとするスクリプトに関連するトピックを選ぶことが出来る。典型的には、ユーザが所定の機能を理解するのを助ける為、サンプル・ワーキング・コード、即ち、スクリプトがヘルプ・ファイルに含まれている。ユーザは例を強調表示し、「コピー」指令を使って例をコピーし、その後「貼り付け」指令を使って、この指令をスクリプト・エディタに貼り付けることが出来る。ユーザは、スクリプトを直接的に使って指令を実行するか、又は別のスクリプトに含める為にスクリプトを編集することが出来る。
【0055】
観察テンプレート・エディタのツールの場合について云うと、前に述べたように、観察テンプレートはスクリーンの配置(レイアウト)であり、この配置は複数のセルで構成されており、各々のセルには画像(単独又は多重フレーム)、曲線又はオーバーレー・グラフィックスを入れることが出来る。1実施態様では、観察テンプレート・エディタ(RTE)は、ユーザが観察テンプレートをグラフ式に組み立てることが出来るようにする。
【0056】
図3はRTEに対する1実施態様のユーザ・インターフェイス200を示す。インターフェイス200は、作られたセルを表示する表示区域202を含み、ユーザが種々の機能を容易に選ぶことが出来るようにする「ファイル」メニュー204が設けられている。更に、画像、曲線及びROIデータに対する特定の数学的な又は臨床的な処理を行う為にデータ処理指令206が設けられている。標準的な1組のデータ処理指令と、こういうデータ処理指令206に対する詳細なヘルプ・ファイルが設けられる。アドレスされる全体的な機能区域は、画像及び曲線の演算と、画像の閾値作用と、画像の切り取り、コピー及び貼り付けと、画像及び曲線の統計と、画像のフィルター作用(空間及び周波数)と、曲線のフィルター作用と、画像のフレーム組替えと、画像の向き(回転、方位及び鏡)と、画像の寸法取り(任意の寸法)と、ROI処理(論理動作)とである。
【0057】
ツールは、ユーザがプログラム、即ちスクリプトを容易に且つ素早く作成することが出来るようにする。もちろん、各々の実行に全てのツールが必要ではないこと、並びに他の実行にはこの他のツールが望ましいことがあることが考えられる。従って、種々のツールについてこれまで説明したことは、例に過ぎず、本発明をそれに制限するつもりはない。
【0058】
[学習モード]図4は、本発明の1実施態様に従って学習モードのプログラム能力を達成するように構成されたサブシステムを含むイメージング・システム250のブロック図である。前に説明したように、学習モードは、ユーザがあるシーケンスの動作を稽古し、それらの動作を後で再現されるように保存することが出来るようにするものであり、この学習モードを使うことによって、ユーザは動作のシーケンスを変更することが出来る。本発明の1実施態様に従って学習モードを実施する為、イメージング・システム250が初期設定/装備サブシステム252、及びコード作成サブシステム254を含む。グラフィック・ユーザ・インターフェース(GUI)イベント・ハンドラー・システム256が設けられていて、GUIで起こるイベントを検出すると共に、こういうイベントをコード作成サブシステム254に供給する。後で更に詳しく説明するが、初期設定/装備サブシステム252はシステム構成ファイル258、テーブル・ローダ260及び自動インストーラ262を含む。コード作成サブシステム254はコード作成器264及びコード圧縮システム266を含む。コード圧縮システム266から出力スクリプト268が出力される。サブシステム252及び258は、例えばユーザ・ワークステーション内に構成される。
【0059】
全体について総括的に云うと、システム構成ファイル258が、装備する必要がある全てのウィジットのリストを持っている。出力制御スクリプト268を作成するために使われるシーケンス(テキスト・ストリング)も、対応するウィジット・ネームと並んで、システム構成ファイル258内に表示されている。スタートアップに際し、システム構成ファイル258(これは読取可能なASCIIフォーマットで記憶されている)がロードされる。基本ウィジット(ベースウィジット)から出発して、データ構造内にある各々のウィジットに対するウィジット識別子を探索して記録する。実行の間、あるウィジット(ボタン、メニューの項目など)が作動される(押される)と、内部データ構造から出力制御スクリプト・シーケンスが得られる。このシーケンスを、特定された規則を用いて有効な出力制御スクリプト268に拡張する。制御シーケンスが、特定された規則に従って、出力制御スクリプト268を表す言語を定める。システム250は、単にシステム構成ファイル258を編集することにより、異なるシンタックス又は指令を出力するように実行時間で構成し得る。更に、制御シーケンスは、シェル・スクリプトを含めて異なる出力言語に容易に拡張することが出来る。更に、システム250が、単に動作自体を記録するのではなく、動作の意図を捕捉する形で、ユーザの動作(例えば、キーのクリック及びマウスの動き)のシーケンスを出力指令に解釈する。例えば、2つの画像を付け加える為に、GUIは、付け加えるべき画像を選び、付加動作を選び、選ばれた動作を適用するなどというような一連の動作をユーザが実行することを要求することがある。システム250では、出力が、個別の画像を選ぶプロセスよりもむしろ、ユーザが意図するものとして画像を追加する指令を表す。
【0060】
図5は、システム250の動作を更に詳しく示すデータの流れ図である。前に述べたように、システム構成ファイル258は、所定のアプリケーションを装備し且つ出力スクリプト268を作成するために必要な異なる要素を持っている。システム構成ファイル258内の典型的な行を下記に示す。
【0061】
panUP:panZoomForm.panUp,NORMAL,O,C102G2,VpanY($0panScope,$0panY)
【0062】
この行は下に述べる6つのトークン(要素)を含んでいる。
1.オブジェクト・ネーム(「panUP」)
これは装備される指令の論理名称である。このネームは、後で説明するシステムのGenCode部分で参照される。
2.ウィジット・ネーム(「panZoomForm.panUp」)
これは装備されるウィジットの名称であり、そのウィジットに対する唯一のパス・ネームに対応すべきである。このストリングは、アプリケーション・ウィジット階層内のウィジットをルックアップするために使用され、オブジェクトがウィジットに対応しない場合はNULL(無効)である。
3.オブジェクトの種類(「NORMAL」)
これはオブジェクトの種類を特定する。考えられる選択は次の通りである。
様式(MODAL)
この種類のオブジェクトは直接的に指令を作成せず、オブジェクトにGenCodeが関連しているが、オブジェクトが作動されたときにコードを作成すべきでない場合に使われる。典型的には、アプリケーションの状態を変えるあらゆるオブジェクトはMODALと記される。
デストラクタ/コンストラクタ(DESTRUCTOR/CONSTRUCTOR)
コンストラクタ及びデストラクタ・ウィジットは、オブジェクトが作動された時、ウィジットの数が変わることを示し、コンストラクタ及びデストラクタ・ウィジットは、自動インストーラ162に全てのウィジットを再インストールさせる。
ノーマル(NORMAL)
これは、上に述べた何れの種類でもない全てのウィジットに与えら一般的な種類である。
4.グループ(「0」)
グループは、同様なオブジェクトを同じように取り扱うための便利なメソッドを提供する。
5.圧縮コード(「C102G2」)
圧縮コード(「C102G2」)これは出力コードを再構築する為に使われる。例えば、ユーザがマウスをスクリーンを横切ってドラッグする時、マウスの各々の位置で指令を作成する代わりに、動作の終わりに指令を作成することが望ましいことがある。圧縮コードは、この例のような圧縮を行うのに使われる規則を記述する。
6.GenCode(「VpanY($OpanScope,$OpanY)」)
これは、GUIイベントを有効な出力スクリプトに変換する時にどの規則を使うべきかを特定する。
【0063】
システム構成ファイル258に表されている要素は、装備されたアプリケーションのウィジット階層及び作成された出力スクリプト268と密接な関係を持つ。テーブル・ローダ260が実行時間にシステム構成ファイル258を読取り、システム構成ファイル258から読取った情報を使って、本明細書でマスター・テーブルと呼ぶ内部データ構造270を初期設定する。システム構成ファイル108を実行時間にロード可能なファイルとすることにより、構成に変更を加える為にソフトウェアをコンパイルし直す必要がないので、開発が早められると共に、ファイルは必要がない限りロードされないので、2進ファイルは一層小さくなる。
【0064】
マスター・テーブル270は、テーブル・ローダ260によって読取られた全ての情報、並びに後で説明する自動インストーラ262を使ってアプリケーションGUIから取出された若干の情報を記憶する内部データ構造である。マスター・テーブル270は、システム構成ファイルにある情報を記憶するのに加えて、装備される全てのウィジットのウィジット識別子(ID)を記憶するフィールドをも持っている。1例では、マスター・テーブル構造は次のようになっている。
【0065】
typedef struct { char object[MAX_COM_LEN};
char button_name[MAX_WIDGET_NAME] Widget w;
LMCommandType com_type;
LMCompression compression;
char GenCode;
}LMMasterTab;
【0066】
自動インストーラ262は、マスター・テーブル270に記憶されている「ウィジット・ネーム」を使って、GUIアプリケーションから関連するウィジットを見つけ、そのウィジットのIDをマスター・テーブル270に記憶する。自動インストーラ262は、ネームを付したウィジット階層272を持つ任意のGUIアプリケーションに作用するように適応させることが出来る。例えば、Xウィンドウズ・アプリケーションでは、自動インストーラ262は、Xt指令を使ってウィジット、即ち、XtNameToWidgetを見つける。各々のウィジットを探索する為、自動インストーラ262は、アプリケーションに対する基本ウィジットのIDを必要とするが、これは、初期設定の呼の一部分として、システム250に送られたウィジットから、適当なネームのウィジットが見つかるまで、アプリケーション・ウィジット階層272を昇ることによって見つけられる。
【0067】
ウィジット階層272の一例が図6に示されている。図6に示すように、この例のウィジット階層272は基本ウィジット274を含む。この階層の中にpanZoomForm形のウィジット276があり、これがpanZoomForm形装備の総称である。panUPウィジット278が、panZoomFormウィジット276の1形式であり、従って、panUPウィジット278はpanZoomFoorm形ウィジット276より下位にあって、それに接続されている。
【0068】
再び図5について説明すると、MODALでない全てのオブジェクトに対し、自動インストーラ262がcallback機能を呼び出すcallbackを付加する。自動インストーラ262はウィジットのタイプも決定する。「装備された」ウィジットによって呼出された時、それをマスター・テーブル270で検索し、コード作成器264をインデックスによりエントリーに呼込む。
【0069】
コード作成器264はマスター・テーブル270のGenCode部分を使って、特定されたGUI動作に対応するスクリプト指令を出力する。コード作成器264は$n(nは数)で始まりその後に英字が続く任意のストリングを正規の表式”$[0−9][a−zA−Z]+”として、例えば”$0panUp”として拡張することによって、テキストを「評価」する。英字が「オブジェクト・ネーム」を表す。評価すべきオブジェクトがウィジットである場合、ウィジットの値を戻し、出力指令に”$n<object>”テキストを入れ替える。例えば、”panUp”が、テキスト「123.4」を含んでいたテキストウィジットに対するオブジェクト・ネームであった場合、GenCodeでは、ストリング”print$0panUp”は、マスター・テーブル270でpanUpを見ることにより、”print123.4”に変更される。
【0070】
コード作成器264は$01F(”...”=”...”)<result>[$0else<else result>]表式をも拡張する。=の両辺を評価し、その後ストリングを比較する。「真」であれば、<result>を評価して使う。「虚偽」であれば、<else result>を評価して使う。GenCodeは評価が簡単であって、コードを複雑にして拡大するlex又はyaccを使う必要がない。
【0071】
コード圧縮器とも呼ばれることのあるコード圧縮システム266について云うと、コード圧縮は、システム構成ファイル258から読取った圧縮コードによって制御される。ユーザが、コード圧縮システム266なしに、動作、例えばズーム・アップを繰り返すと、システム250はマウス・ボタンを押す毎に新しい指令を作成する。コード圧縮システム266は、重複した行が現れた時、それを除去する。コード圧縮システム266は、現在の指令及び前の指令から出力変数I($n<object name>表式)を抽出し、比較する。マスクされていないオブジェクト・ネームの全ての副次表式が同じである場合、出力は前の出力の代わりであると考えられる。システム266は前の出力を追跡し、新しい出力が代わりであると考えられる場合、前の出力を削除する。
【0072】
上に述べた動作を要約すると、テーブル・ローダ260がシステム構成ファイル258を読取り、システム構成ファイル258から読取った情報を使って、マスター・テーブル270を初期設定する。自動インストーラ262が、マスター・テーブル270に記憶されている「ウィジット・ネーム」を使って、GUIアプリケーションから関連するウィジットを見つけ、そのウィジットのIDをマスター・テーブル270に記憶する。システムのGUIで作業するユーザは、一連のイベントを入力し、それらがGUIイベント・ハンドラー・システム256によって記録される。コード作成器264が、特定された各々のGUIの動作に対応するスクリプト指令を出力する。コード圧縮システム266が現在の指令及び前の指令からの出力変数を抽出し、出力変数を圧縮コードにある1及び0と比較する。マスクされていない全てのウィジット・ネームの副次表式が同じであれば、出力が前の出力の代わりと考えられる。コード圧縮システム266が前の出力を追跡し、新しい出力が代わりとされる場合、前の出力を削除する。コード圧縮システム266がスクリプト268を出力する。
【0073】
この場合も、前に説明したように、システム250は、単にシステム構成ファイルを編集することにより、異なるシンタックス又は指令を出力するように、実行時間で構成し得るという重要な利点を持つ。更に、内部制御シーケンス拡張論理を容易に拡張して、シェル・スクリプトを含めて異なる言語を出力することが出来る。
【0074】
[同期動作]本発明の一面は、下位の非同期的なアーキテクチュアに対する非ブロッキング同期インターフェイスとなるアルゴリズムに関する。全体的に云うと、このアルゴリズムはアプリケーションのクライアント/サーバ部分を同期的な開発の環境から切り離す。クライアント部分又はユニットとサーバ部分又はユニットとは、別々のコンピュータ又は1個のコンピュータにあっても良い。このアルゴリズムを使うと、プログラマは非同期的なプログラミング方式に頼らずに、非ブロッキングの、高度に対話型のクライアント/サーバ形アプリケーションを開発することが出来る。その結果得られるコードは同期的であって、非常に読取り易く、こじんまりしていて、クライアント/サーバ形アーキテクチュアのプログラミングに習熟していない実務家によっても開発することが出来る。更に、このアルゴリズムは、多重実行スレッドの本質的な支援を持つか又は持っていないオペレーティング・システムで実施することが出来る。
【0075】
図7は、本発明の1実施態様に従って同期的な実行をする為の方法の工程のシーケンスを示すフローチャート300であるが、アプリケーションのクライアント/サーバ部分が、要請−明け渡し−返答の細部を取り扱うコードである。開発環境は埋込みインタープリタである。両方の装置は、単一の実行スレッドを持つ同じプロセスにあるが、アルゴリズムは多重実行スレッドに対して実行し得る。
【0076】
図7について具体的に説明すると、最終ユーザが実行時間にコード又はスクリプトを開発する。このコードがインタープリタにより302の所で実行される。クライアント/サーバ形のトランザクションを必要とするスクリプト指令では、即ちサーバ要請304では、インタープリタは、アプリケーションのクライアント/サーバ部分にある適当な機能を発動するようにプログラムされている。サーバ要請304を出す前および/又は出した後、アプリケーションのクライアント/サーバ部分がインタープリタを中断して、明け渡す(306)。GUIを管理するクライアント/ サーバは、待ち期間の間対話状態に留まる。
【0077】
対話状態に留まる為、実行スレッドをアイドル状態(XtMainLoop)308に戻す。サービス要請が完了していないと(310)、イベントが引き続いて処理される(312)。要請に対応する返答が到着して処理されると(314)、アプリケーションのインタープリタ部分を再開し(316)、その後、インタープリタのプログラム・カウンタ(PC)は中断したところから継続する。その後の処理はスクリプト行302の実行に戻る。
【0078】
図8は、図7に示した方法の工程により切り離された実行の一例を示す。この例では、2つの非同期的な動作を実行しなければならない。ボックス350には、クライアント/サーバ側の高レベルのタスクが示されている。これらのタスクは実際のコードの何行かを表しており、その為図示のプログラム・カウンタ(PC)は、実際のプロセッサPCに直接的に対応しない。中央の列は、クライアント/サーバ擬似PCが変化する時のインタープリタPCの進行を示す。クライアント/サーバPCがインタープリタPCよりも更に早く変化すること並びに非同期的な動作の間、インタープリタPCが休眠状態になることに注意されたい。ボックス352には、アプリケーション・タスクが示されている。非同期的動作が完了する時、インタープリタPCを目ざめさせる。
【0079】
特定の一つの構成では、商用Basicインタープリタをアプリケーションに埋込む。インタープリタは、アプリケーションに結合されたライブラリとして送り出される。インタープリタ・ライブラリが、インタープリタを中断し、インタープリタを再開させ、プログラミング言語を拡張し、クライアント/サーバ形アプリケーションの機能を呼び出し、クライアント/サーバ形アプリケーションからスクリプト機能/サブルーチンを実行し、インタープリタとアプリケーションの間で情報をやりとりする機関になる。アプリケーションがUNIXオペレーティング・システムで実行され、Xウィンドウ・システムを使う。具体的に云うと、アプリケーションはX Intrinsics(Xt)、Motif Wedgetツールキット(Xm)及びXプロトコル・ライブラリXlibで構成される。この他のクライアント側ライブラリも、夫々のサーバと連絡する為にアプリケーションによって使われる。インタープリタ・ライブラリから得れる文書拡張機構を使って、Basic言語に拡張が加えられる。この拡張は、クライアント・サーバ機能を発動することによりタスクを実行する。アプリケーションは、スレッドに対する明確なオペレーティング・システムの支援を使わずに実施される。即ち、アプリケーション・プロセスに対して単一の実行スレッドを用いる。しかし、このアプリケーションは、プロセス当たり多重の実行スレッドを支援するオペレーティング・システムに適している。多重実行スレッドを支援すれば、スタックを解きほぐす必要が少なくなるので、この方式の性能が高まる。
【0080】
前に述べたように、コードは同期的で、非常に読取り易く、こじんまりしていて、クライアント/サーバ形アーキテクチュアのプログラミングに習熟していない実務者によって開発することが出来る。更に、アルゴリズムは、多重実行スレッドの本質的な支援を持つ又は持たないオペレーティング・システムで実施することが出来る。
【0081】
[オーバーラップ検出及び補正]前に述べたように、観察テンプレートは、医学的な診断情報を観察することに関係する画像、曲線、テキスト及びその他の患者情報のグラフ表示である。観察テンプレートを組立てる時、典型的には矩形セルを組立てる。スクリーン上のセルの配置を選び、これらのセルの属性の明細を作成する。セルは画像、曲線、テキスト並びに診断プロセスに関連するその他の情報を入れることが出来る。セルはタイリングされ、オーバーラップがあると重要な診断情報が隠れるので、オーバーラップの無いことが好ましい。本発明の一面は、手作業のセル・アラインメント・タスクを加速することによって使い易さを高めることが出来る自動的なオーバーラップ検出及び補正アルゴリズムである。
【0082】
更に具体的に云うと、一実施例においては、矩形セル・オーバーラップ検出及び補正アルゴリズムが提供される。このアルゴリズムは、ユーザのアラインメント動作の意図を正確に実行するようにする。一形式では、アルゴリズムが、観察テンプレート(RT)を作成する観察テンプレート・エディタに統合される。
【0083】
一実施態様のオーバーラップ検出及び補正アルゴリズムのフローチャート400が図9に示されている。図9に示すように、アルゴリズムは2回通過形対話形アルゴリズムであって、セルの配置形状が変更された時のオーバーラップを除こうとするものである。配置形状の変更は、セルの寸法又は場所の変更である。
【0084】
更に具体的に説明すると、セル配置形状変更402(開始)に応答して、セルオーバーラップ検出器404が呼び出される。オーバーラップが検出されなければ、ユーザ要請が点406(終わり)に示すように首尾よく実行されている。オーバーラップが検出されると、ブロック408で、アルゴリズムを呼び出して、オーバーラップを補正する為に、変更されたセルを移動させなければならない最小距離Dminを計算する。Dminをオーバーラップ補正器410に送り、このオーバーラップ補正器によりセルを距離Dminだけ移動させる。距離Dminだけ移動したことにより、セルの別の区域に別のオーバーラップが起こることがあり、その為、再びブロック412の所でオーバーラップを検査する。補正によって別のオーバーラップが生じなかった場合、動作が実行されており、アルゴリズムは点406(終わり)に示すように首尾よく終了する。別のオーバーラップが見つかった場合、新しい距離Dminをブロック414の所で計算し、オーバーラップ補正器416に送って、そこでセルを新しい距離Dminだけ移動させる。新しい距離Dminだけ移動したことにより、セルの別の区域で別のオーバーラップが起こることがあり、その為ブロック418で再びオーバーラップがあるかどうか検査する。補正によって別のオーバーラップが生じなかった場合、動作が実行されており、点406(終わり)に示すようにアルゴリズムが首尾よく終了する。別のオーバーラップが見つかった場合、オーバーラップ補正過程は、ユーザに対するエラーメッセージ420と共に終了する。これ以上のパスをすると、セルの詰め込み(パッキング)が起こるので、これ以上の補正パスは行わない。この詰め込み動作は、うまくはめ合わせる可能性もあったのに、セルを比較的大きな距離だけ移動しなければならないかもしれないこと、それ以上のパスによっても決して終わることの無い(無限探索になる)ことを含めて、望ましくない副作用がある。第1の副作用、即ちセルが初めの位置からかなり離れた場所に来るということは、セルがユーザが特定した場所に接近した状態を保つという重要な目標に違反する。
【0085】
図10を参照して、セルのオーバーラップ404、412,418を決定することについて説明すると、このオーバーラップは、その配置形状が変更されたセルと、カンバス上にある残りのセルとの間の線形検査を実施することによって決定される。セルのオーバーラップを決定するために下記の4つの状態が検査され、これらの状態は図10に例示されている。
【0086】
状態1. 変更されたセルの隅が別のセルの内側にある。
状態2. 別のセルの隅が、変更されたセルの内側にある。
状態3. どの隅も別のセルの内側にはないが、2つのセルが交差する。
状態4. 変更されたセルがカンバスの縁を越えて伸びる。
【0087】
変更されたセルを他の1つのセルからオーバーラップを補正する為に移動させる必要のある最小の距離Dminは、移動するセルがオーバーラップしている各々のセルに対し、下記の距離を決定し、そのうちの最小値に戻ることによって見つける。
【0088】
1.移動するセルの頂部から、オーバーラップしたセルの底部までの距離。
2.移動するセルの底部から、オーバーラップしたセルの頂部までの距離。
3.移動するセルの左辺から、オーバーラップしたセルの右辺までの距離。
4.移動するセルの右辺から、オーバーラップしたセルの左辺までの距離。
【0089】
2つのセルのオーバーラップが極くわずかである場合、ルーチンはその内の一番左側のオーバーラップの小さいセルを保存する。これでも、1つのセルをオーバーラップが極く小さいと一意的に確認するのに十分ではない場合、一番下側のオーバーラップの小さいセルに戻る。
【0090】
オーバーラップ補正ルーチン410、416は、オーバーラップが極く小さいセル及び最小距離を入力とする。その後、オーバーラップを補正する方向にそのセルを最小距離だけ移動する。最小距離が2つ又は更に多くの方向で同じである場合、変更されたセルを、右、左、上及び下という優先順位で移動する。こういう優先順位は、オーバーラップが決まる方向が見つかるまで、逐次的に評価する。このオーバーラップ検出及び補正アルゴリズムは、セルのタイリングが実質的に自動化され、且つ積み重ねを避けるようにユーザと対話型であるという利点がある。
【0091】
上に述べたプログラム可能なシステムはユーザにとって極めて親しみやすく、臨床医はこのシステムを使って、イメージング・アプリケーションを比較的容易に素早く開発することが出来ると考えられる。更に、このシステムを使って作成されたスクリプトは、多くの異なる環境で使うように移し替えが容易に出来、この為、環境の如何に関わらず、余分の相当の労力及び費用をかけずに、画像及びデータを医者の希望に従って医者が観察することが出来るように表示することが出来る。更に、クライアント/サーバ形アーキテクチュアを利用したが、要請−明け渡し−返答形のパラダイムでコードを入れる煩わしさを避けながら、長いトランザクションの間でも、システムの対話能力が温存される。更に、観察テンプレートの作成について云うと、自動的なオーバーラップ検出及び補正は、手作業のセル・アラインメント・タスクを加速することにより、使い易さを高めることが出来る。
【0092】
本発明の種々の実施態様についてこれまで説明したところから、本発明の目的が達成されたことは明らかである。本発明を詳しく説明し、図面に示したが、これは例示の為に過ぎず、本発明を制約するものと解してはならないことを承知されたい。従って、本発明の範囲は、特許請求の範囲によって限定されることを承知されたい。
【図面の簡単な説明】
【図1】本発明の1実施態様によるプログラム可能なシステムの為の一例のユーザ・インターフェースを示す模写図である。
【図2】学習モードを実行した結果を表示する一例の学習モード捕捉窓を示す模写図である。
【図3】観察テンプレート・エディタに対する1実施態様のユーザ・インターフェースの模写図である。
【図4】本発明の1実施態様の学習モード・システムのブロック図である。
【図5】図4にブロック図で示したシステム内のデータの流れを示すデータ・フローチャートである。
【図6】ウィジット階層の1例を示す図である。
【図7】本発明の1実施態様に従って同期的な実行を行うプロセスのシーケンスを示すフローチャートである。
【図8】本発明の1実施態様に従って切り離された1例の同期的な指令実行を示す構成図である。
【図9】本発明の1実施態様によるオーバーラップ検出及び補正アルゴリズムのフローチャートである。
【図10】本発明の1実施態様によるセル・オーバーラップ検出及び補正アルゴリズムに関連して検査されるセル・オーバーラップ状態を示す説明図である。
【符号の説明】
100 ユーザ・インターフェイス
102 ナビゲーション区域
104、106 タブ
108 ボタン
116 メニュー
118 スクリプト・エディタ窓
120 アクティブ・ヘルプ窓
122 画像区域
150 学習モード捕捉窓
200 RTE用のユーザ・インターフェイス
250 イメージング・システム
252 初期設定/計装サブシステム
254 コード作成サブシステム
272 ウィジット階層
Claims (3)
- メモリ装置を持つコンピュータと、オブジェクトに対するユーザの動作に基づいてGUIイベントを生成するプログラムとして前記コンピュータ内に構成されるグラフィック・ユーザ・インターフェース、前記オブジェクトに対する前記GUIイベントを検出するプログラムとして前記コンピュータ内に構成されるグラフィック・ユーザ・インターフェース・イベント・ハンドラー・システム(256)を含む、スクリプト作成システムに於いて、
(1)前記グラフィック・ユーザ・インターフェース・イベント・ハンドラー・システム及び前記メモリ装置に結合されていて、前記メモリ装置に記憶されているシステム構成ファイル(258)からのデータを装備させるように前記メモリ装置に記憶されたマスタ・テーブル(270)を変更するプログラムとして前記コンピュータ内に構成された設定サブシステムであって、
(a)前記マスタ・テーブル(270)は、前記システム構成ファイル(258)からのウィジットのオブジェクトネーム、ウィジットネーム、及び、スクリプト指令を作成するために使われるテキスト・ストリングを含んでいる、前記コンピュータ上で実現される、前記設定サブシステム(252)と、
(2)前記マスタ・テーブル(270)及び前記グラフィック・ユーザ・インタフェース・イベント・ハンドラー・システムに結合されていて、前記イベント・ハンドラー・システムによって前記メモリ装置に記録される各々のGUIイベントに対応する画像の表示処理を制御する為のスクリプト指令を作成するプログラムとして前記コンピュータ内に構成されたコード作成サブシステム(254)であって、
(a)前記コード作成サブシステムは、前記スクリプト指令を出力するために、前記画像の表示処理を再現するために行われた、前記イベント・ハンドラー・システムによって記録された前記オブジェクトに対する前記GUIイベントにより特定されるオブジェクト・ネームを、前記マスタ・テーブル(270)に装備されているウィジットのオブジェクト・ネームから探索し出力すべきスクリプト指令を得るように構成されており、
(b)前記コード作成サブシステムは、コード作成器(264)を含んでおり、
(c)前記コード作成器(264)は、前記テキスト・ストリング中の正規の表式が前記マスタ・テーブルに装備されているテキストウィジットのオブジェクトネームを表す場合には、該正規の表式を該テキストウィジットに対応する値(123.4)に変更してスクリプト指令を出力し、
(d)前記コード作成サブシステムは、前記コンピュータ上で実現される、前記コード作成サブシステム(254)とを有しているスクリプト作成システム。 - 前記設定サブシステムは、前記システム構成ファイルを読取って前記マスター・テーブルを設定するテーブル・ローダ(260)を含んでいる請求項1記載のスクリプト作成システム。
- 前記コード作成サブシステムは、更に、前記コード作成器から出力されたスクリプト指令を受け取り、現在の指令及び前の指令の一部を比較して、両者が一致すれば、前の指令を削除するように構成されているコード圧縮サブシステム(266)を含んでいる請求項1記載のスクリプト作成システム。
Applications Claiming Priority (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US08/696,121 US5950002A (en) | 1996-08-13 | 1996-08-13 | Learn mode script generation in a medical imaging system |
US08/696121 | 1996-08-13 |
Publications (2)
Publication Number | Publication Date |
---|---|
JPH10232767A JPH10232767A (ja) | 1998-09-02 |
JP4731643B2 true JP4731643B2 (ja) | 2011-07-27 |
Family
ID=24795787
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
JP21747797A Expired - Fee Related JP4731643B2 (ja) | 1996-08-13 | 1997-08-12 | スクリプト作成システム |
Country Status (4)
Country | Link |
---|---|
US (1) | US5950002A (ja) |
JP (1) | JP4731643B2 (ja) |
CA (1) | CA2211373C (ja) |
IL (1) | IL121511A (ja) |
Families Citing this family (27)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
GB0007860D0 (en) * | 2000-03-31 | 2000-05-17 | Glaxo Group Ltd | Quantative analysis of biological images |
US7009626B2 (en) * | 2000-04-14 | 2006-03-07 | Picsel Technologies Limited | Systems and methods for generating visual representations of graphical data and digital document processing |
US7251810B1 (en) * | 2000-04-26 | 2007-07-31 | Microsoft Corporation | Minimal instrumentation for lossless call profiling |
US7020868B2 (en) * | 2000-11-22 | 2006-03-28 | General Electric Company | Graphic application development system for a medical imaging system |
US6964024B2 (en) * | 2001-02-07 | 2005-11-08 | Xerox Corporation | Operator-defined visitation sequence of client user interface controls |
US7020844B2 (en) * | 2001-11-21 | 2006-03-28 | General Electric Company | Method and apparatus for managing workflow in prescribing and processing medical images |
WO2003043501A1 (fr) * | 2001-11-22 | 2003-05-30 | Kabushiki Kaisha Toshiba | Echographe, systeme d'edition de flux de travail, et procede de controle de l'echographe |
US7197744B2 (en) * | 2002-04-04 | 2007-03-27 | Honeywell International, Inc. | Universal script editor |
JP3966179B2 (ja) * | 2003-01-06 | 2007-08-29 | ブラザー工業株式会社 | ドライバソフト設定システム、コンピュータ、ドライバソフト設定方法、及びプログラム |
WO2005022464A1 (en) * | 2003-08-29 | 2005-03-10 | Koninklijke Philips Electronics N.V. | A method, a device and a computer program arranged to develop and execute an executable template of an image processing protocol |
US20050131856A1 (en) * | 2003-12-15 | 2005-06-16 | O'dea Paul J. | Method and system for adaptive user interfacing with an imaging system |
US7259696B1 (en) * | 2004-02-10 | 2007-08-21 | Zilog, Inc. | Interactive web-based codeset selection and development tool |
US7490295B2 (en) | 2004-06-25 | 2009-02-10 | Apple Inc. | Layer for accessing user interface elements |
US8302020B2 (en) | 2004-06-25 | 2012-10-30 | Apple Inc. | Widget authoring and editing environment |
JP4672321B2 (ja) * | 2004-09-28 | 2011-04-20 | 株式会社東芝 | 放射線モニタシステム |
WO2007036879A1 (en) * | 2005-09-30 | 2007-04-05 | Koninklijke Philips Electronics, N.V. | User interface system and method for creating and managing ultrasound measurment-based calculations in ultrasound imaging systems |
US7752556B2 (en) | 2005-10-27 | 2010-07-06 | Apple Inc. | Workflow widgets |
US7707514B2 (en) | 2005-11-18 | 2010-04-27 | Apple Inc. | Management of user interface elements in a display environment |
DE102005061796A1 (de) * | 2005-12-23 | 2007-06-28 | Siemens Ag | Verfahren zur Modifikation einer Anzahl von Prozesssteuerungsprotokollen |
US8954871B2 (en) | 2007-07-18 | 2015-02-10 | Apple Inc. | User-centric widgets and dashboards |
CN101896124B (zh) * | 2007-12-17 | 2013-03-13 | 皇家飞利浦电子股份有限公司 | 用于在诊断成像系统中创建协议的方法 |
US8924881B2 (en) * | 2008-02-24 | 2014-12-30 | The Regents Of The University Of California | Drill down clinical information dashboard |
US8381124B2 (en) * | 2008-07-30 | 2013-02-19 | The Regents Of The University Of California | Single select clinical informatics |
CN102133139B (zh) * | 2011-01-21 | 2013-05-15 | 华南理工大学 | 一种假手控制系统及其控制方法 |
US9244707B2 (en) * | 2011-01-25 | 2016-01-26 | Microsoft Technology Licensing, Llc | Transforming user interface actions to script commands |
US9262178B2 (en) * | 2012-01-30 | 2016-02-16 | Intel Corporation | Method for reducing platform boot times by providing lazy input/output abstractions |
US10740540B2 (en) * | 2013-12-13 | 2020-08-11 | Freedom Scientific, Inc. | Techniques for programmatic magnification of visible content elements of markup language documents |
Family Cites Families (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5159687A (en) * | 1989-11-14 | 1992-10-27 | Caseworks, Inc. | Method and apparatus for generating program code files |
US5465378A (en) * | 1990-05-15 | 1995-11-07 | Compuspeak, Inc. | Report generating system |
EP0487110B1 (en) * | 1990-11-22 | 1999-10-06 | Kabushiki Kaisha Toshiba | Computer-aided diagnosis system for medical use |
US5660176A (en) * | 1993-12-29 | 1997-08-26 | First Opinion Corporation | Computerized medical diagnostic and treatment advice system |
US5704371A (en) * | 1996-03-06 | 1998-01-06 | Shepard; Franziska | Medical history documentation system and method |
-
1996
- 1996-08-13 US US08/696,121 patent/US5950002A/en not_active Expired - Lifetime
-
1997
- 1997-07-24 CA CA002211373A patent/CA2211373C/en not_active Expired - Fee Related
- 1997-08-11 IL IL12151197A patent/IL121511A/xx not_active IP Right Cessation
- 1997-08-12 JP JP21747797A patent/JP4731643B2/ja not_active Expired - Fee Related
Also Published As
Publication number | Publication date |
---|---|
IL121511A0 (en) | 1998-02-08 |
IL121511A (en) | 2000-02-17 |
US5950002A (en) | 1999-09-07 |
CA2211373A1 (en) | 1998-02-13 |
CA2211373C (en) | 2006-09-19 |
JPH10232767A (ja) | 1998-09-02 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
JP4731643B2 (ja) | スクリプト作成システム | |
US5961610A (en) | Systems, methods and apparatus for generating and controlling display of medical images | |
JP4059547B2 (ja) | クライアント/サーバ型の医療用イメージング・システムで指令を実行する方法 | |
JP4201363B2 (ja) | セル・オーバーラップ検出及び補正方法 | |
JP3565850B2 (ja) | オブジェクト指向通知フレームワークシステム | |
JP3798014B2 (ja) | バルーン・ヘルプ・システム | |
JP3407809B2 (ja) | コンピュータ・アプリケーション・ソフトウェアの自動化試験システム | |
US5317688A (en) | Software agent used to provide instruction to a user for a plurality of computer applications | |
JP4612069B2 (ja) | データを表現し操作する方法 | |
US7653896B2 (en) | Smart UI recording and playback framework | |
KR101076867B1 (ko) | 콘텐츠를 생성하기 위한 자동 이미지 캡처 | |
EP3338179B1 (en) | Graphical representation of data in a program code editor | |
US6904563B2 (en) | Editing platforms for remote user interface translation | |
US8135572B2 (en) | Integrated debugger simulator | |
JP2008146664A (ja) | メニュー項目表示方法および装置 | |
KR100562905B1 (ko) | 어플리케이션 프로그램 모듈의 동적 배치 방법 | |
JP4686117B2 (ja) | ソースコード変換装置、ソースコード変換方法、およびプログラム | |
JPH08314760A (ja) | プログラム開発支援装置 | |
Griffiths et al. | NET Windows forms in a nutshell | |
JP3119939B2 (ja) | アプリケーションプログラムを実行するシステム | |
Cameron et al. | Design-Time Support | |
JPWO2005071547A1 (ja) | データベース操作装置およびその方法 | |
Baker | CONVERSION OF THE BAND DIAGRAM PROGRAM: A LOOK AT PORTABILITY, EFFICIENCY AND EASE OF USE. | |
JPH1115645A (ja) | 実行可能プログラム作成装置および実行可能プログラム作成方法 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
A621 | Written request for application examination |
Free format text: JAPANESE INTERMEDIATE CODE: A621 Effective date: 20040812 |
|
A131 | Notification of reasons for refusal |
Free format text: JAPANESE INTERMEDIATE CODE: A131 Effective date: 20061107 |
|
A601 | Written request for extension of time |
Free format text: JAPANESE INTERMEDIATE CODE: A601 Effective date: 20070207 |
|
A602 | Written permission of extension of time |
Free format text: JAPANESE INTERMEDIATE CODE: A602 Effective date: 20070220 |
|
A521 | Request for written amendment filed |
Free format text: JAPANESE INTERMEDIATE CODE: A523 Effective date: 20070427 |
|
A02 | Decision of refusal |
Free format text: JAPANESE INTERMEDIATE CODE: A02 Effective date: 20070529 |
|
A521 | Request for written amendment filed |
Free format text: JAPANESE INTERMEDIATE CODE: A523 Effective date: 20070824 |
|
A911 | Transfer to examiner for re-examination before appeal (zenchi) |
Free format text: JAPANESE INTERMEDIATE CODE: A911 Effective date: 20071001 |
|
A912 | Re-examination (zenchi) completed and case transferred to appeal board |
Free format text: JAPANESE INTERMEDIATE CODE: A912 Effective date: 20071019 |
|
A601 | Written request for extension of time |
Free format text: JAPANESE INTERMEDIATE CODE: A601 Effective date: 20091019 |
|
A602 | Written permission of extension of time |
Free format text: JAPANESE INTERMEDIATE CODE: A602 Effective date: 20091023 |
|
RD04 | Notification of resignation of power of attorney |
Free format text: JAPANESE INTERMEDIATE CODE: A7424 Effective date: 20091026 |
|
A601 | Written request for extension of time |
Free format text: JAPANESE INTERMEDIATE CODE: A601 Effective date: 20100729 |
|
A602 | Written permission of extension of time |
Free format text: JAPANESE INTERMEDIATE CODE: A602 Effective date: 20100818 |
|
A521 | Request for written amendment filed |
Free format text: JAPANESE INTERMEDIATE CODE: A523 Effective date: 20101013 |
|
A521 | Request for written amendment filed |
Free format text: JAPANESE INTERMEDIATE CODE: A523 Effective date: 20101111 |
|
A521 | Request for written amendment filed |
Free format text: JAPANESE INTERMEDIATE CODE: A523 Effective date: 20110311 |
|
A01 | Written decision to grant a patent or to grant a registration (utility model) |
Free format text: JAPANESE INTERMEDIATE CODE: A01 |
|
A61 | First payment of annual fees (during grant procedure) |
Free format text: JAPANESE INTERMEDIATE CODE: A61 Effective date: 20110420 |
|
FPAY | Renewal fee payment (event date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20140428 Year of fee payment: 3 |
|
R150 | Certificate of patent or registration of utility model |
Free format text: JAPANESE INTERMEDIATE CODE: R150 |
|
R250 | Receipt of annual fees |
Free format text: JAPANESE INTERMEDIATE CODE: R250 |
|
LAPS | Cancellation because of no payment of annual fees |