Methods and apparatus for making a hypermedium interactive

Information

  • Patent Grant
  • 8285782
  • Patent Number
    8,285,782
  • Date Filed
    Friday, September 23, 2011
    12 years ago
  • Date Issued
    Tuesday, October 9, 2012
    11 years ago
Abstract
The present disclosure is directed to a system and method of making a hypermedium page interactive. Responsive to a user selecting a hyperlink on a hypermedium page displayed on a client node, a client agent located on the client node establishes a communications link from the client agent to an application execution server agent on an application server using information located in a hyperlink configuration file, corresponding to the hyperlink displayed on the client node, obtained from the network server node. Responsive to the creation of the communications link between the application execution server agent and the client agent, the application executes on the application execution server and the user is capable of interactively using the application running on the application execution node from the client node. Data input and display occurs at the client node under the control of the client agent.
Description
FIELD OF THE INVENTION

The invention relates generally to the field of computer communications and more specifically to the field of remote application processing.


BACKGROUND

A hypermedium is a graphical display which contains a series of graphic and textual images which are referred to as hyperlinks Each hyperlink typically corresponds to additional information which is available to a user of the hypermedium. For example a hypermedium display might be an encyclopedic article about flight. If the graphical display of the article includes a picture of a rocket, and if the user is able to obtain information about the engine of the rocket by selecting (typically by using a pointing device referred to as a computer mouse) a portion of the display showing the engine, the portion of the picture containing the rocket engine is referred to as a hyperlink. That is, the portion of the picture containing the engine is a link to information about the engine. The activation of a hyperlink causes the hypermedium to request a data file of the desired information from the program actually controlling the hypermedium.


When a hypermedium is used in conjunction with a network, for example the world wide web or the internet, a user on a client node on the network first accesses what is termed a home page or a web page. This home page or web page is obtained from another node on the net, termed a network server, and is displayed on the client node by a program termed a network browser or web browser. In such a case, when the user selects the hyperlink (in the previous example, the portion of the display showing the rocket engine) a request is made to the network browser for the data file containing the requested information. The network browser on the user's node establishes communication with the network node, the data server, having data corresponding to the requested hyperlink. In this case the node having information about the rocket engine contains the information required by the hyperlink.


Although hypermedium has been used to transfer information to a user in the manner just discussed, it is desirable to be able to use a hypermedium display to interactively execute applications such as database programs located on another computer, an application execution server, on the network. The present invention relates to a method and apparatus to accomplish this task.


SUMMARY OF THE INVENTION

The invention relates to a system of making a hypermedium page interactive to thereby permit an application to be executed on one node and the results displayed and data entered on another node. In one embodiment the system includes a client node, a network server node and an application execution server node interconnected by a communication link. A hyperlink on the hypermedium page is displayed on the client node and a hyperlink configuration file (corresponding to the hyperlink on the client node) is located on the network server node. In one embodiment, a client agent is located on the client node and a server agent is located on the application execution server node. A communication link is created by the client agent between the client agent on the client node and the server agent on the application execution server node in response to data in the hyperlink configuration file. The system also includes an application on the application execution server node which executed on the application execution server node in response to the communications link between the client agent and the server agent. The application running on the application execution node then communicates with the client agent through the server agent. The client agent on the client node is responsible for receiving data input from the user and transferring the data to the application on the application execution node and receiving data from the application on the application execution node and displaying data output to the user on the client node.


The invention also relates to a method of making a hypermedium page interactive. The method includes the steps of selecting a hyperlink on the hypermedium page displayed on a client node; retrieving (from a server node to the client node) a hyperlink configuration file corresponding to the hyperlink and starting a client agent on the client node. The method further includes the steps of creating a communications link between a server agent on an application execution server and the client agent; starting the application on the application execution server in response to the connection; communicating data between the client agent on the client node and application on the application execution node; and managing the display and input of data on the client node.





BRIEF DESCRIPTION OF THE DRAWINGS

Other features and benefits of the invention can be more clearly understood with reference to the specification and the accompanying drawings in which:



FIG. 1 is a block diagram of an embodiment of the system of the invention; and



FIG. 2 is a flow chart of the operation of system of the invention shown in FIG. 1.





DETAILED DESCRIPTION OF THE INVENTION

Referring to FIG. 1, and in brief overview, an embodiment of an interactive hypermedium system of the invention includes a client node 10, a network server node 18 and an application execution server node 24 interconnected by a communications link 32, herein referred to without any loss of generality as a network or web. Although only one client node 10, network server node 18 and application execution server node 24, are shown in FIG. 1 for clarity, an actual network may include many such nodes. Alternatively, the services provided by each of the nodes listed may be combined in one or more nodes. For example, the application execution server and the network server may in fact be the same node. In the extreme it is possible for all functions to be performed by the same node, although such would not typically be the case. In addition, although only one application 36 is shown on the application execution server 24, in reality, an application execution server node 24 typically includes many applications 36. Each node on the network or web 32 includes a processor, which may vary significantly from other processors on the web 32 in terms of computing power and associated hardware. Further, the applications 36 available for execution on each node may be different.


A user on a client node wishing to run the application program 36 which is located on the application execution server 24 on the web 32 does so through a graphical user interface 40, which is herein referred to without any loss of generality as a hypermedium, located on the client node 10. The graphical interface is displayed on a graphical display device 42. Data is entered by the users through a mouse 46 and a keyboard 50 located on the client node 10. The graphical display or page 44 which the user first views on the hypermedium 40 is referred to herein without any loss of generality as the home page or web page of the application 36. A page 44 or home page of the hypermedium 40 includes a graphic link 48 or textual link 56 herein referred to without any loss of generality as a hyperlink. The web page is displayed by a process 64 referred to herein without any loss of generality as a network browser 64 executing on the client node 10.


The network browser 64 obtains the first page or web page 44 from a network server node 18 and displays the web page 44 on the hypermedium 40 for the user to view on the graphical display device 42. When the user selects an application program 36 to execute (by selecting a graphical 48 or textual 56 hyperlink using the mouse 46 or keyboard 50) the network browser 64 obtains a network configuration file 68 corresponding to the selected application 36 from a predetermined network server 18 and starts a client agent 72 which will communicate with the selected application 36. This will be discussed in more detail below.


The client agent 72 reads the configuration file 68 and establishes a communications link to a server agent 80 on the application execution server 24 specified by the configuration file 68. In one embodiment, the configuration file 68 includes the name of the application and the node location of the application 36 corresponding to the hyperlink 48, 56. The configuration file may also contain optional information such as authentication or authorized user information. Server agent 80 performs the operations necessary (such as authentication) to permit the client agent 72 access to the application 36, and once access is permitted, starts the application 36 requested by the user. Once the application 36 is executing on the application execution server, the application 36 communicates through the server agent 80 directly with the client agent 72 without intervention by the network browser 64. The client agent 72 is then responsible for receiving data from the user through the mouse 46 and keyboard 50 and transmitting it to the application program 36 the application execution server 24. Similarly, the client agent 72 is responsible for receiving data from the application 36 on the application execution server 24 and displaying the data in an application display window 74 on the graphical display device 42 on the client node 10. It should be noted that the application display window 74 may be located within the boundaries or outside the boundaries of the hypermedium 40. When the application 36 is completed the server agent 80 instructs the client agent 72 to disconnect the communication link 32 between the client agent 72 and the server agent 80 and the server agent waits for the next connection.



FIG. 2 depicts the operation of the system in more detail. Initially, the client agent 72 is registered (Step 1) with the network browser 64 of the client node 10 and an entry is made in the network browser's registration file 88 (FIG. 1). This entry permits the network browser 64 to start the client agent 72 whenever a given file type is requested by the hyperlink 48, 56 of the hypermedium 40. In this case the client agent 72 is designed to permit a user on the client node 10 to execute and interact with a remote application 36 on an application execution server node 24. The client agent 72 would be registered with the network browser 64 such that whenever a hyperlink 48, 56 requested the given file type (for example .RMT for remote execution) from the network browser 64, the network browser 64 would start the client agent 72 which would permit remote execution and interaction with an application 36 resident on an application execution server 24. The invoking of the client agent 72 is discussed in more detail below.


Next, when a user wishes to execute an application from a hypermedium environment, for example a database program, the hypermedium 40 is displayed in a manner that is well known to those skilled in the art. When the user selects a hyperlink 48, 56 on the page 44 of the hypermedium (Step 2) by using the mouse 46 or keyboard 50 on the client node 10, a request is made to the network browser 64 for the corresponding data file (Step 3). In this example, the filetype (.RMT) is requested.


The network browser 64 obtains the corresponding configuration file 68 from the network server 18 which is specified in the file request made by the hyperlink 48, 56 to the network browser 64 (Step 4). The network browser 64 then compares the obtained configuration file 68 with the registration file 88 of client agent names which it maintains (Step 5). If the client agent 72 specified by the configuration file 68 is found in the registration file 88, the client agent 72 is started (Step 6).


The invoked client agent 72 reads the configuration file 68 (Step 7), and based upon the information in the configuration file 68, begins to establish a communication link with the server agent 80 on the application execution server 24 (Step 8), in this case the sales database application execution server (generally 24).


Considering the process of beginning the communications link of step 8 (FIG. 2) in more detail, communication begins with the server agent 80 monitoring communication activity on the network 32. At this point, no protocol assumptions are made by the server agent 80 beyond those necessary for the transport layer. Similarly, the client agent 72 also makes no assumption of the communications protocol beyond that required by the transport layer. Once the server agent 80 determines that a client agent 72 is attempting to communicate with it, the server agent 80 transmits a message to the client agent 72 indicating that service is available.


Once the client agent 72 determines that service is available on the application execution server node 24, the client agent 72 transmits a message to the server agent 80 indicating that it is ready to proceed with the communication protocol. Once the server agent 80 has responded that it is ready to continue the communication protocol, the client agent 72 enables the protocol necessary for it to run the application 36. In response to the message from the client agent 72, the server agent 80 also enables the required protocol. The server agent 80 then transmits a message using the required protocol indicating that the client agent's request has been received and accepted.


In response the client agent 72 and the server agent 80 exchange a set of messages which negotiate the parameters under which communications will occur. Once negotiations are complete, the client agent 72 and the server agent 80 are able to communicate as necessary for the application 36 to be run by the user.


Once the communications protocol has been established and the server agent 80 has authenticated the client agent 72 (Step 9) (for example determining that the user has permission to read and write to the database) the application 36 (Step 10) is run on the application execution server 24. At this point application 36 running on the application execution server 24 is communicating via the server agent 80 with the client agent 72 on the client node 10. The client agent 72 is now responsible for transmitting data input by the user using the mouse 46 and keyboard 50 to the application 36 running on the application execution server 24. Further, the client agent 72 is responsible for receiving data for display from the application 36 and displaying that data in the application window 74 on the graphical display device 42 of the client node 10.


It should be noted that the underlying presentation protocol which passes data to a transport layer such as TCP/IP must be capable of transferring graphical information. Examples of such protocols which may be used for interactive hypermedia communication include public domain X-WINDOWS protocol and the proprietary ICA protocol of Citrix Systems Inc.


Thus the above described system permits a user on a client node 10, which may have very limited resources, to start and interact with an application program 36 located on another application execution server node 24. The application 36 then runs on the application execution server node 24 and the data is input and the results displayed on the client node 10.


These and other examples of the concept of the invention illustrated above are intended by way of example and the actual scope of the invention is to be determined solely from the following claims.

Claims
  • 1. A method of obtaining application data, the method comprising: selecting, by a client computing device, a hyperlink within a graphical interface of a web portal displayed on a display device in communication with the client computing device, the hyperlink corresponding to an application;receiving, in response to the selection of the hyperlink, a configuration file associated with the hyperlink;identifying, using the received hyperlink file, a server capable of executing the corresponding application;establishing a communication protocol providing communication between the identified server and the client computing device, the communication protocol facilitating communication over one or more channels;receiving, from the server via one of the channels, application data generated by the application executing on the server; anddisplaying the received application data on the display device.
  • 2. The method of claim 1, wherein establishing a communication protocol further comprises establishing a communication protocol that facilitates communication over multiple channels.
  • 3. The method of claim 1, wherein establishing a communication protocol further comprises establishing a transport layer communication between the client computing device and the identified server;enabling a communication protocol above the transport layer; andnegotiating parameters of the communication protocol above the transport layer via the established transport layer communication.
  • 4. The method of claim 3, wherein receiving application data comprises receiving application data via the communication protocol above the transport layer.
  • 5. The method of claim 1, further comprising obtaining a hypermedium page from a network prior to selecting a hyperlink, the hypermedium page including the selected hyperlink.
  • 6. The method of claim 1, wherein identifying a server further comprises identifying a server executing the application.
  • 7. The method of claim 1, wherein identifying a server further comprises identifying a server executing a plurality of instances of the application.
  • 8. A non-transitory computer readable medium having instructions executable by a processor within a client computing device to obtain application data, the computer readable medium comprising: non-transitory computer-readable instructions to select a hyperlink within a graphical interface of a web portal displayed on a display device in communication with a client computing device, the hyperlink corresponding to an application;non-transitory computer-readable instructions to receive, in response to the selection of the hyperlink, a configuration file associated with the hyperlink;non-transitory computer-readable instructions to identify, using the received configuration file, a server capable of executing the corresponding application;non-transitory computer-readable instructions to establish a communication protocol providing communication between the identified server and the client computing device, the communication protocol facilitating communication over one or more channels;non-transitory computer-readable instructions to receive, from the server via one of the channels, application data generated by the application executing on the server; andnon-transitory computer-readable instructions to display the received application data on the display device.
  • 9. The computer readable medium of claim 8, wherein non-transitory computer-readable instructions to establish a communication protocol further comprises non-transitory computer-readable instructions to establish a communication protocol that facilitates communication over multiple channels.
  • 10. The computer readable medium of claim 8, wherein non-transitory computer-readable instructions to establish a communication protocol further comprises non-transitory computer-readable instructions to establish a transport layer communication between the client computing device and the identified server;enable a communication protocol above the transport layer; andnegotiate parameters of the communication protocol above the transport layer via the established transport layer communication.
  • 11. The computer readable medium of claim 10, wherein non-transitory computer-readable instructions to receive application data comprise non-transitory computer-readable instructions to receive application data via the communication protocol above the transport layer.
  • 12. The computer readable medium of claim 8, further comprising non-transitory computer-readable instructions to obtain a hypermedium page from a network prior to selecting a hyperlink, the hypermedium page including the selected hyperlink.
  • 13. The computer readable medium of claim 8, wherein non-transitory Computer-readable instructions to identify a server further comprises non-transitory-computer-readable instructions to identify a server executing the application.
  • 14. The computer readable medium of claim 8, wherein non-transitory computer-readable instructions to identify a server further comprises non-transitory computer-readable instructions to identify a server executing a plurality of instances of the application.
CROSS REFERENCE TO RELATED APPLICATIONS

This application is a continuation of application Ser. No. 12/054,987 filed on Mar. 25, 2008 (now U.S. Pat. No. 8,090,793), which is a continuation of application Ser. No. 10/689,824 filed on Oct. 20, 2003 (now U.S. Pat. No. 7,359,953), which is a continuation of application Ser. No. 10/068,790 filed on Feb. 6, 2002 (now U.S. Pat. No. 6,691,157), which is itself a continuation of application U.S. Ser. No. 09/247,220 filed on Feb. 10, 1999 (now U.S. Pat. No. 6,370,570), which is itself a continuation of application U.S. Ser. No. 08/556,623 filed on Nov. 13, 1995 (now U.S. Pat. No. 6,088,515), all of which are incorporated herein by reference.

US Referenced Citations (223)
Number Name Date Kind
4387425 El-Gohary Jun 1983 A
4499499 Brickman et al. Feb 1985 A
RE32632 Atkinson Mar 1988 E
4779189 Legvold et al. Oct 1988 A
4860247 Uchida et al. Aug 1989 A
4887204 Johnson et al. Dec 1989 A
4903218 Longo et al. Feb 1990 A
4937036 Beard et al. Jun 1990 A
4937784 Masai et al. Jun 1990 A
4949281 Hillenbrand et al. Aug 1990 A
4958303 Assarpour et al. Sep 1990 A
4974173 Stefik et al. Nov 1990 A
5014221 Mogul May 1991 A
5031089 Liu et al. Jul 1991 A
5062060 Kolnick Oct 1991 A
5072412 Henderson et al. Dec 1991 A
5103303 Shoji et al. Apr 1992 A
5119319 Tanenbaum Jun 1992 A
5155847 Kirouac et al. Oct 1992 A
5175852 Johnson et al. Dec 1992 A
5187790 East et al. Feb 1993 A
5202971 Henson et al. Apr 1993 A
5204897 Wyman Apr 1993 A
5204947 Bernstein et al. Apr 1993 A
5231697 Yamada Jul 1993 A
5233701 Nakata et al. Aug 1993 A
5241625 Epard et al. Aug 1993 A
5247683 Holmes et al. Sep 1993 A
5249290 Heizer Sep 1993 A
5255361 Callaway et al. Oct 1993 A
5297249 Bernstein et al. Mar 1994 A
5301270 Steinberg et al. Apr 1994 A
5305440 Morgan et al. Apr 1994 A
5307490 Davidson et al. Apr 1994 A
5309555 Akins et al. May 1994 A
5315711 Barone et al. May 1994 A
5325527 Cwikowski et al. Jun 1994 A
5329619 Page et al. Jul 1994 A
5333237 Stefanopoulos et al. Jul 1994 A
5341477 Pitkin et al. Aug 1994 A
5341478 Travis, Jr. et al. Aug 1994 A
5351129 Lai Sep 1994 A
5367688 Croll Nov 1994 A
5412727 Drexler et al. May 1995 A
5414457 Kadowaki et al. May 1995 A
5430876 Schreiber et al. Jul 1995 A
5440719 Hanes et al. Aug 1995 A
5457797 Butterworth et al. Oct 1995 A
5461608 Yoshiyama Oct 1995 A
5469540 Powers et al. Nov 1995 A
5473599 Li et al. Dec 1995 A
5483466 Kawahara et al. Jan 1996 A
5485460 Schrier et al. Jan 1996 A
5499343 Pettus Mar 1996 A
5509070 Schull Apr 1996 A
5515508 Pettus et al. May 1996 A
5517617 Sathaye et al. May 1996 A
5524253 Pham et al. Jun 1996 A
5526492 Ishida et al. Jun 1996 A
5530852 Meske, Jr. et al. Jun 1996 A
5537546 Sauter et al. Jul 1996 A
5537548 Fin et al. Jul 1996 A
5541927 Kristol et al. Jul 1996 A
5548726 Pettus Aug 1996 A
5551030 Linden et al. Aug 1996 A
5553242 Russell et al. Sep 1996 A
5557539 Fitch Sep 1996 A
5557732 Thompson Sep 1996 A
5557748 Norris Sep 1996 A
5557765 Lipner et al. Sep 1996 A
5561769 Kumar et al. Oct 1996 A
5566302 Khalidi et al. Oct 1996 A
5572643 Judson Nov 1996 A
5572674 Ernst Nov 1996 A
5574934 Mirashrafi et al. Nov 1996 A
5577188 Zhu Nov 1996 A
5579469 Pike Nov 1996 A
5583563 Wanderscheid et al. Dec 1996 A
5583992 Kudo et al. Dec 1996 A
5586312 Johnson et al. Dec 1996 A
5592626 Papadimitriou et al. Jan 1997 A
5594490 Dawson et al. Jan 1997 A
5596745 Lai et al. Jan 1997 A
5604490 Blakley et al. Feb 1997 A
5606493 Duscher et al. Feb 1997 A
5619716 Nonaka et al. Apr 1997 A
5623603 Jiang et al. Apr 1997 A
5623656 Lyons Apr 1997 A
5640454 Lipner et al. Jun 1997 A
5644720 Boll et al. Jul 1997 A
5657390 Elgamal et al. Aug 1997 A
5668999 Gosling Sep 1997 A
5671379 Kuse et al. Sep 1997 A
5680549 Raynak et al. Oct 1997 A
5701451 Rogers et al. Dec 1997 A
5706437 Kirchner et al. Jan 1998 A
5708780 Levergood et al. Jan 1998 A
5708786 Teruuchi Jan 1998 A
5710918 Lagarde et al. Jan 1998 A
5721876 Yu et al. Feb 1998 A
5724514 Arias Mar 1998 A
5727155 Dawson Mar 1998 A
5734865 Yu Mar 1998 A
5737416 Cooper et al. Apr 1998 A
5737592 Nguyen et al. Apr 1998 A
5742762 Scholl et al. Apr 1998 A
5742778 Hao et al. Apr 1998 A
5745573 Lipner et al. Apr 1998 A
5748892 Richardson May 1998 A
5752246 Rogers et al. May 1998 A
5754830 Butts et al. May 1998 A
5757915 Aucsmith et al. May 1998 A
5757925 Faybishenko May 1998 A
5758085 Kouoheris et al. May 1998 A
5761507 Govett Jun 1998 A
5761656 Ben-Shachar Jun 1998 A
5761662 Dasan Jun 1998 A
5764908 Shoji et al. Jun 1998 A
5764915 Heimsoth et al. Jun 1998 A
5767849 Borgendale et al. Jun 1998 A
5768614 Takagi et al. Jun 1998 A
5790977 Ezekiel Aug 1998 A
5794207 Walker et al. Aug 1998 A
5802258 Chen Sep 1998 A
5802306 Hunt Sep 1998 A
5812784 Watson et al. Sep 1998 A
5819093 Davidson et al. Oct 1998 A
5826027 Pedersen et al. Oct 1998 A
5828840 Cowan et al. Oct 1998 A
5838906 Doyle et al. Nov 1998 A
5838910 Domenikos et al. Nov 1998 A
5838916 Domenikos et al. Nov 1998 A
5842206 Sotomayor Nov 1998 A
5844553 Hao et al. Dec 1998 A
5848410 Walls et al. Dec 1998 A
5855015 Shoham Dec 1998 A
5860068 Cook Jan 1999 A
5862325 Reed et al. Jan 1999 A
5870545 Davis et al. Feb 1999 A
5872973 Mitchell et al. Feb 1999 A
5874960 Mairs et al. Feb 1999 A
5877757 Baldwin et al. Mar 1999 A
5889942 Orenshteyn Mar 1999 A
5909545 Frese, II et al. Jun 1999 A
5909677 Broder et al. Jun 1999 A
5913060 Discavage Jun 1999 A
5913920 Adams et al. Jun 1999 A
5923842 Pedersen et al. Jul 1999 A
5928324 Sloan Jul 1999 A
5930804 Yu et al. Jul 1999 A
5938733 Heimsoth et al. Aug 1999 A
5940075 Mutschler et al. Aug 1999 A
5941949 Pedersen Aug 1999 A
5941988 Bhagwat et al. Aug 1999 A
5944791 Scherpbier Aug 1999 A
5949975 Batty et al. Sep 1999 A
5951694 Choquier et al. Sep 1999 A
5956403 Lipner et al. Sep 1999 A
5961586 Pedersen Oct 1999 A
5973696 Agranat et al. Oct 1999 A
5978847 Kisor et al. Nov 1999 A
5978848 Maddalozzo, Jr. et al. Nov 1999 A
5983190 Trower et al. Nov 1999 A
5991406 Lipner et al. Nov 1999 A
5999179 Kekic et al. Dec 1999 A
5999950 Krueger et al. Dec 1999 A
6006242 Poole et al. Dec 1999 A
6012087 Freivald et al. Jan 2000 A
6023721 Cummings Feb 2000 A
6034689 White et al. Mar 2000 A
6038696 Chouly et al. Mar 2000 A
6052732 Gosling Apr 2000 A
6058480 Brown May 2000 A
6078956 Bryant et al. Jun 2000 A
6088515 Muir et al. Jul 2000 A
6101507 Cane et al. Aug 2000 A
6108712 Hayes, Jr. Aug 2000 A
6108715 Leach et al. Aug 2000 A
6157944 Pedersen Dec 2000 A
6157953 Chang et al. Dec 2000 A
6161126 Wies et al. Dec 2000 A
6167432 Jiang Dec 2000 A
6173332 Hickman Jan 2001 B1
6175854 Bretscher Jan 2001 B1
6185609 Rangarajan et al. Feb 2001 B1
6199082 Ferrel et al. Mar 2001 B1
6199753 Tracy et al. Mar 2001 B1
6226618 Downs et al. May 2001 B1
6263363 Rosenblatt et al. Jul 2001 B1
6272493 Pasquali Aug 2001 B1
6272556 Gish Aug 2001 B1
6272632 Carman et al. Aug 2001 B1
6289461 Dixon Sep 2001 B1
6292827 Raz Sep 2001 B1
6338086 Curtis et al. Jan 2002 B1
6367012 Atkinson et al. Apr 2002 B1
6370570 Muir et al. Apr 2002 B1
6374237 Reese Apr 2002 B1
6539429 Rakavy et al. Mar 2003 B2
6609198 Wood et al. Aug 2003 B1
6691157 Muir et al. Feb 2004 B2
6691232 Wood et al. Feb 2004 B1
RE38598 Frese, II et al. Sep 2004 E
6950991 Bloomfield et al. Sep 2005 B2
6952714 Peart Oct 2005 B2
7007070 Hickman Feb 2006 B1
7080127 Hickman et al. Jul 2006 B1
7100069 Hickman et al. Aug 2006 B1
7117243 Peart Oct 2006 B2
7130888 Hickman et al. Oct 2006 B1
7228426 Sinha et al. Jun 2007 B2
7359953 Muir et al. Apr 2008 B2
7599985 Doyle et al. Oct 2009 B2
20010056547 Dixon Dec 2001 A1
20020035451 Rothermel Mar 2002 A1
20020052932 Curtis et al. May 2002 A1
20030037134 Hickman Feb 2003 A1
20030063119 Bloomfield et al. Apr 2003 A1
20030063324 Takaoka Apr 2003 A1
20050188203 Bhaskaran et al. Aug 2005 A1
20050210118 Hickman et al. Sep 2005 A1
20060184798 Yaldwyn et al. Aug 2006 A1
20060282520 Hickman et al. Dec 2006 A1
Foreign Referenced Citations (29)
Number Date Country
0 381 645 Aug 1990 EP
0 384 339 Aug 1990 EP
0381645 Aug 1990 EP
0384339 Aug 1990 EP
0 414 624 Feb 1991 EP
0 475 581 Mar 1992 EP
0 483 576 May 1992 EP
0483576 May 1992 EP
0 540 151 May 1993 EP
0540151 May 1993 EP
0 643 514 Mar 1995 EP
0 648 038 Apr 1995 EP
0648038 Apr 1995 EP
0 732 834 Sep 1996 EP
0732834 Sep 1996 EP
0 767 563 Apr 1997 EP
0 841 615 May 1998 EP
0 878 759 Nov 1998 EP
06-332782 Dec 1994 JP
06332782 Dec 1994 JP
WO-9315457 Aug 1993 WO
WO-9414114 Jun 1994 WO
WO-9718518 May 1997 WO
WO-9728623 Aug 1997 WO
WO-9852320 Nov 1998 WO
WO-9852344 Nov 1998 WO
WO-9852320 Nov 1998 WO
WO-9852344 Nov 1998 WO
WO-9963430 Dec 1999 WO
Related Publications (1)
Number Date Country
20120072486 A1 Mar 2012 US
Continuations (5)
Number Date Country
Parent 12054987 Mar 2008 US
Child 13242921 US
Parent 10689824 Oct 2003 US
Child 12054987 US
Parent 10068790 Feb 2002 US
Child 10689824 US
Parent 09247220 Feb 1999 US
Child 10068790 US
Parent 08556623 Nov 1995 US
Child 09247220 US