US20130110259A1 - Event Management Systems and Methods for Motion Control Systems - Google Patents
Event Management Systems and Methods for Motion Control Systems Download PDFInfo
- Publication number
- US20130110259A1 US20130110259A1 US13/719,112 US201213719112A US2013110259A1 US 20130110259 A1 US20130110259 A1 US 20130110259A1 US 201213719112 A US201213719112 A US 201213719112A US 2013110259 A1 US2013110259 A1 US 2013110259A1
- Authority
- US
- United States
- Prior art keywords
- event
- motion
- data
- recited
- media
- 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.)
- Abandoned
Links
- 230000033001 locomotion Effects 0.000 title claims abstract description 291
- 238000000034 method Methods 0.000 title description 126
- 230000009471 action Effects 0.000 claims description 12
- 238000013515 script Methods 0.000 claims description 6
- 230000001419 dependent effect Effects 0.000 claims description 3
- 230000008569 process Effects 0.000 description 39
- 235000014510 cooky Nutrition 0.000 description 31
- 238000004891 communication Methods 0.000 description 19
- 238000011144 upstream manufacturing Methods 0.000 description 18
- 239000008186 active pharmaceutical agent Substances 0.000 description 14
- 238000012545 processing Methods 0.000 description 13
- 238000005516 engineering process Methods 0.000 description 7
- 230000006870 function Effects 0.000 description 7
- 238000012544 monitoring process Methods 0.000 description 7
- 230000003993 interaction Effects 0.000 description 6
- 230000000007 visual effect Effects 0.000 description 6
- 230000008859 change Effects 0.000 description 5
- 238000013507 mapping Methods 0.000 description 5
- 238000013461 design Methods 0.000 description 4
- 230000007246 mechanism Effects 0.000 description 4
- 230000004044 response Effects 0.000 description 4
- 230000008901 benefit Effects 0.000 description 3
- 238000013480 data collection Methods 0.000 description 3
- 238000002347 injection Methods 0.000 description 3
- 239000007924 injection Substances 0.000 description 3
- 238000007726 management method Methods 0.000 description 3
- 238000012360 testing method Methods 0.000 description 3
- 238000010304 firing Methods 0.000 description 2
- 238000011093 media selection Methods 0.000 description 2
- 230000007935 neutral effect Effects 0.000 description 2
- 238000003825 pressing Methods 0.000 description 2
- 230000003068 static effect Effects 0.000 description 2
- 238000013519 translation Methods 0.000 description 2
- 230000001960 triggered effect Effects 0.000 description 2
- WQZGKKKJIJFFOK-GASJEMHNSA-N Glucose Natural products OC[C@H]1OC(O)[C@H](O)[C@@H](O)[C@@H]1O WQZGKKKJIJFFOK-GASJEMHNSA-N 0.000 description 1
- 101000686246 Homo sapiens Ras-related protein R-Ras Proteins 0.000 description 1
- 102100024683 Ras-related protein R-Ras Human genes 0.000 description 1
- 230000003213 activating effect Effects 0.000 description 1
- 208000006673 asthma Diseases 0.000 description 1
- 239000008280 blood Substances 0.000 description 1
- 210000004369 blood Anatomy 0.000 description 1
- 238000013500 data storage Methods 0.000 description 1
- 230000003111 delayed effect Effects 0.000 description 1
- 230000009977 dual effect Effects 0.000 description 1
- 238000007429 general method Methods 0.000 description 1
- 239000008103 glucose Substances 0.000 description 1
- 239000012092 media component Substances 0.000 description 1
- 239000002184 metal Substances 0.000 description 1
- 238000012986 modification Methods 0.000 description 1
- 230000004048 modification Effects 0.000 description 1
- 230000008520 organization Effects 0.000 description 1
- 238000007781 pre-processing Methods 0.000 description 1
- 230000011664 signaling Effects 0.000 description 1
- 239000000344 soap Substances 0.000 description 1
- 238000001356 surgical procedure Methods 0.000 description 1
- 230000005641 tunneling Effects 0.000 description 1
- XLYOFNOQVPJJNP-UHFFFAOYSA-N water Substances O XLYOFNOQVPJJNP-UHFFFAOYSA-N 0.000 description 1
Images
Classifications
-
- G—PHYSICS
- G05—CONTROLLING; REGULATING
- G05B—CONTROL OR REGULATING SYSTEMS IN GENERAL; FUNCTIONAL ELEMENTS OF SUCH SYSTEMS; MONITORING OR TESTING ARRANGEMENTS FOR SUCH SYSTEMS OR ELEMENTS
- G05B19/00—Programme-control systems
- G05B19/02—Programme-control systems electric
- G05B19/18—Numerical control [NC], i.e. automatically operating machines, in particular machine tools, e.g. in a manufacturing environment, so as to execute positioning, movement or co-ordinated operations by means of programme data in numerical form
- G05B19/408—Numerical control [NC], i.e. automatically operating machines, in particular machine tools, e.g. in a manufacturing environment, so as to execute positioning, movement or co-ordinated operations by means of programme data in numerical form characterised by data handling or data format, e.g. reading, buffering or conversion of data
-
- G—PHYSICS
- G05—CONTROLLING; REGULATING
- G05B—CONTROL OR REGULATING SYSTEMS IN GENERAL; FUNCTIONAL ELEMENTS OF SUCH SYSTEMS; MONITORING OR TESTING ARRANGEMENTS FOR SUCH SYSTEMS OR ELEMENTS
- G05B15/00—Systems controlled by a computer
- G05B15/02—Systems controlled by a computer electric
-
- 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/46—Multiprogramming arrangements
- G06F9/54—Interprogram communication
- G06F9/542—Event management; Broadcasting; Multicasting; Notifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L9/00—Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols
- H04L9/40—Network security protocols
-
- G—PHYSICS
- G05—CONTROLLING; REGULATING
- G05B—CONTROL OR REGULATING SYSTEMS IN GENERAL; FUNCTIONAL ELEMENTS OF SUCH SYSTEMS; MONITORING OR TESTING ARRANGEMENTS FOR SUCH SYSTEMS OR ELEMENTS
- G05B2219/00—Program-control systems
- G05B2219/30—Nc systems
- G05B2219/34—Director, elements to supervisory
- G05B2219/34263—OLE object linking and embedding, OPC ole for process control
-
- G—PHYSICS
- G05—CONTROLLING; REGULATING
- G05B—CONTROL OR REGULATING SYSTEMS IN GENERAL; FUNCTIONAL ELEMENTS OF SUCH SYSTEMS; MONITORING OR TESTING ARRANGEMENTS FOR SUCH SYSTEMS OR ELEMENTS
- G05B2219/00—Program-control systems
- G05B2219/30—Nc systems
- G05B2219/36—Nc in input of data, input key till input tape
- G05B2219/36035—Special language, task programming, oop object oriented programming
-
- G—PHYSICS
- G05—CONTROLLING; REGULATING
- G05B—CONTROL OR REGULATING SYSTEMS IN GENERAL; FUNCTIONAL ELEMENTS OF SUCH SYSTEMS; MONITORING OR TESTING ARRANGEMENTS FOR SUCH SYSTEMS OR ELEMENTS
- G05B2219/00—Program-control systems
- G05B2219/30—Nc systems
- G05B2219/36—Nc in input of data, input key till input tape
- G05B2219/36037—Application programming interface associates component code with driver function
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L67/00—Network arrangements or protocols for supporting network services or applications
- H04L67/01—Protocols
- H04L67/131—Protocols for games, networked simulations or virtual reality
Definitions
- the present invention relates to motion control systems and, more specifically, to an event management system optimized for the processing and distribution of events associated with a motion control device.
- Electromechanical systems are used in numerous environments to translate electrical signals into mechanical movement.
- factory automation systems, toys, appliances, and the like all may use one or more electromechanical transducers that move in response to electrical control signals.
- the present invention may be embodied as a part of an overall motion control system as described in the Brown et al. patents and will be described herein in that context.
- the principles of the present invention may have broader application to other motion control systems and methods, and the scope of the present invention should be determined by the claims appended hereto and not the following detailed description.
- the present invention may be embodied as a motion control system comprising a machine platform, at least one event destination, and an event handler.
- the machine platform carries out automated tasks and generates events.
- the event handler is configurable to receive at least one event from the machine platform and send the at least one event to the at least one event destination.
- FIG. 1 is a module interaction map depicting a motion control system incorporating an event management system of the present invention
- FIG. 2 is a scenario map depicting the startup and initialization of the system of FIG. 1 ;
- FIG. 3 is a scenario map depicting the process of injecting a motion event provider DLL into the address space of a target application
- FIG. 4 is a scenario map depicting the process of configuring motion events provided by each of one or more motion event providers 132 ;
- FIG. 5 is a scenario map depicting the process of handling a motion event
- FIG. 6 is a scenario map depicting how a user may obtain new motion media and motion event providers 132 from the motion web site 136 ;
- FIG. 7 is a scenario map depicting shut down of the system of FIG. 1 ;
- FIG. 8 is a scenario map depicting the mapping of text to motion events
- FIG. 9 is a module interaction map depicting interactions of modules forming another example motion control system of the present invention.
- FIG. 10 is a module interaction map depicting an event handling system constructed using a modular output model
- FIG. 11 is a use case depicting the configuration of an event handling component from an application
- FIG. 12 is a use case depicting the configuration of an event handling component from another component
- FIG. 13 is a use case depicting the initialization of an event handling component
- FIG. 14 is a use case depicting the manner in which the event handling component processes events
- FIG. 15 is a use case depicting the manner in which the event handling component processes commands
- FIG. 16 is a use case depicting the manner in which events and commands are processed in a daisy chain of event handling components
- FIG. 17 is a use case depicting the manner in which an event handling component passes configuration data to other event handling components in a daisy chain configuration
- FIG. 18 is a module layout depicting the interfaces exposed by the event handling component
- FIG. 19 depicts an example a user interface screen used to configure connection and start-up settings
- FIG. 20 depicts an example user interface screen used to configure event monitoring settings
- FIG. 21 depicts an example user interface screen used to configure data collection settings.
- the motion control system 120 is an event-based system used to control, configure, and query one or more motion based devices or machines such as indicated by reference character 122 in the drawing.
- the motion based devices or machines 122 will be referred to herein as the target device.
- data In the context of the motion control systems described herein, data is often associated with events.
- data includes any numeric or string data values collected from a target machine or device in an analog or digital format that is made compatible for computer systems. For example, BIT, BYTE, WORD, DWORD, LONG, REAL, DOUBLE, FLOAT, STRING, ASCII STRING are a few data types that represent data items.
- Data may be collected from data sources by reading register values on the data source, reading shared memory provided by the data source, sending commands to the data source for which a data response is given containing the data requested, reading variables provided by the data source, reading and writing to variables in a sequence necessary to produce data values, querying data using a proprietary or standard data protocol, calling a function provided by the target data source, etc.
- the term “variable” as used herein refers to a data item that has both a name and optionally associated data.
- a data item may be a function call, a named data variable, a tag within a database, or the like.
- the terms “variable” and “data item” are used interchangeably to refer to a data point that includes one or more atomic data elements.
- the motion control system 120 comprises the motion based machine or device 122 , a motion event manager 130 , one or more motion event provider objects 132 , a motion event interface 134 , a motion web site 136 , and a media creation tool 138 .
- the system 120 is adapted to be run on a general purpose computer platform comprising computer hardware and an operating system 140 .
- the exemplary operating system 140 is a Windows variant and comprises a registry 142 .
- the web site 136 and media creation tool 138 provide access to one or more motion media files 144 .
- the motion media files 144 contain what will be referred to herein as motion media.
- motion media includes motion scripts, motion application programs, and/or individual motion instructions capable of causing the target device 122 to perform a desired motion operation comprising a discrete movement or sequence of movements.
- the motion media comprises what will be referred to as motion commands.
- motion commands will be used herein to refer to both control commands and media commands associated with a desired motion operation.
- control commands refers to device-specific commands that may be directly run by a target device to obtain a desired motion operation.
- media commands refers to machine independent instructions that generically define a desired motion operation. Normally, media commands are converted into control commands before the target device executes the desired motion operation corresponding to a particular media command or set of media commands.
- application program will be used to refer to a set of control and/or media commands associated with a sequence of discrete movements.
- application refers to client software that uses the functionality of the example motion control systems described herein.
- An application is typically an executable, but may also be a DLL, component, or other module that takes advantage of the functionality of the motion control systems described herein.
- module refers to a binary block of computer logic that contains functions, objects, components, ActiveX components, .NET source, HTML, XML and/or other computer code that can be executed in real-time or in script form.
- a module include an executable EXE, a dynamic link library DLL, an OLE component or set of components housed within a DLL or EXE, an ActiveX Control, an HTML or XML based Control, a VB script source file, a Java Serverlet, Java Control, Java Object, .NET Package, etc.
- the motion event manager 130 comprises a motion control component 150 and an event handling component 152 .
- the motion event interface 134 further comprises a event provider configuration control 154 and a media view control 156 .
- the term “component” refers to a logical organization of computer logic designed to perform a set of operations.
- a component is an OLE Component, an ActiveX Control, an HTML or XML based Control, an HTML or XML based object, a .NET object, a Visual Basic based object, etc.
- the motion control system 120 operates basically as follows.
- the motion event providers 132 generate what will be referred to as event tokens based on the occurrence of a predetermined event.
- the event token is associated with the predetermined event in advance and thus identifies the predetermined event.
- the event token may also contain additional information such as the source of the predetermined event, parameters associated with the predetermined event, and the like.
- the event tokens are sent to the motion event manager 130 .
- the motion event providers 132 and motion event manager 130 run in separate processes and could perhaps run on separate physical machines connected over a network.
- the term “network” refers to a link between two or more computer systems and may be in the form of a packet based network, a streaming based network, broadcast based network, or peer-to-peer based network.
- Several network examples include a TCP/IP network, the Internet, an Intranet, a wireless network using WiFi, a wireless network using radio waves and/or other light based signals, etc.
- the motion event providers 132 and motion event manager 130 thus use the system for the inter-process communication provided by the operating system to transmit the event tokens from the event providers 132 to the motion event manager 130 .
- the motion event manager 130 notifies the motion control component 150 when the event token is received and the identity of the event token.
- the action taken by the motion control component 150 upon receipt of an event token depends upon the nature of the event token.
- the received event token may contain or identify a particular control command, and the motion control component 150 can simply pass that control command to the target device 122 .
- the received event token may contain or identify a particular media command, in which case the motion control component 150 may be required to convert the media command into a control command capable of being run by the target device 122 .
- Another event token may start, stop, or otherwise control a separate application program run by the motion control component 150 .
- the association of motion media with event tokens is preferably made by the motion event manager 130 .
- This association is typically represented by a table, spreadsheet, or other data storage means capable of defining relationships between event tokens and motion media.
- the motion event manager 130 Upon receipt of each event token, the motion event manager 130 will identify the motion media previously associated with the received token and send the identified motion media to the motion control component 150 for control of the target device 122 .
- the motion event manager 130 handles the creation of each event provider 132 installed on the system by creating in-proc providers or injecting other providers into their target processes. The event manager 130 also catches events fired from each provider 132 and initiates the appropriate motion request for each event. In the exemplary system 120 , the event manager 130 is the only object that communicates directly with the motion control component 150 , as will be described in further detail below. The exemplary event manager 130 is accessible by double clicking its icon in the Windows System Tray in a conventional manner.
- the purpose of the event handling component 152 is to handle the inter-process communications between the motion event manager 130 and the motion event providers 132 .
- the exemplary event handling component 152 is or may be a conventional software object referred to as a message pump.
- the motion event provider objects 132 are individually designed to monitor user configurable events from a given source.
- the exemplary system 120 employs two types of motion event providers 132 : simple in-proc servers 132 a,b hosted by the motion event manager 130 and specialty DLLs 132 c,d that are injected into a target process to monitor event cases.
- Each motion event provider object 132 also contains an event configuration control 154 that, as will be described below, allows a user to configure all events supported by the motion event provider objects 132 .
- the motion event provider objects 132 notify the motion event manager 130 of each event caught by the objects 132 .
- the motion event manager 130 and motion control component 150 operate together to allow interaction between the motion event providers 132 and the target device 122 .
- the motion control component 150 may be or incorporate parts of a software system as disclosed, for example, in U.S. Pat. Nos. 5,691,897 and 5,867,385.
- the systems disclosed in the '897 and '385 patents are capable of generating device-specific control commands based on hardware independent media commands written to a predetermined application programming interface.
- the motion control component 150 may act as a conduit that passes device-specific control commands and query responses between the motion event providers 132 and the target device 122 .
- a motion control component implemented in this manner would not convert between hardware independent media commands and device specific control commands.
- a preferred implementation of the motion control component 152 would be to be for the component 152 to function in both a translation mode and in a pass-through mode.
- the component 152 converts media commands into control commands.
- the pass-through mode the component 152 simply passes control commands from the motion event providers 132 to the target devices 122 .
- query responses are returned from the target devices 122 to the event provider 132 in an appropriate format.
- the motion event configuration interface 134 is preferably a visual interface displayed on a screen to allow a user to configure all motion event providers 132 installed on the system 120 .
- the exemplary interface 134 also provides access to the motion web site 136 where new motion media and motion event providers 132 may be downloaded and installed.
- the configuration options allowed by the interface 134 include the ability to enable/disable event providers 132 and map motion media to particular events supported by each provider 132 .
- the interface 134 also provides access to the motion web site 136 , allowing for new motion media and motion event providers 132 to be downloaded and installed onto the current system.
- Each motion event provider 132 contains a visual configuration control 158 that allows the user to configure the events supported by each provider 132 .
- the exemplary configuration controls 158 use the media view control object 156 to gain access to the available motion media in the motion media file 144 that can be mapped to each available event.
- the controls may also be configured to allow the user to add new, customized events to the motion event providers 132 .
- the dynamic events can be defined using parameters such as text (usernames, messages, email, etc.), date/time, or any other parameter particular to an event provider's event source.
- the media view control object 156 provides access to all installed motion media scripts as represented by the motion media file 144 .
- the media view control object 156 displays a conventional browse/select dialog to allow identification and selection of the available motion media.
- This object 156 is used by the event provider configuration controls 158 and allows the configuration controls 158 to remain independent of the motion media format.
- the media creation tool application 138 allows the user to customize and/or create motion media.
- This application 138 preferably implements a graphical, easier to use, front-end user interface design.
- the motion web site 136 provides a location for the user to download new motion media as well as new and/or updated motion event providers 132 .
- the motion media is preferably stored in a single meta file. New motion media downloaded from the motion web site 136 will be added to this meta file.
- the present invention is preferably embodied using the Windows registry; typically, a component category is created for each of the motion event providers 132 , allowing the motion event manager 130 to enumerate all providers 132 installed on the system.
- Primary event sources 132 are user actions (in any active application supported via a motion event provider) and operating system tasks.
- FIG. 2 depicted therein is the scenario describing the startup process of the motion event manager 130 of the system 120 . Each of the steps of this startup process will now be described with reference to FIG. 2 .
- the motion event manager 130 process 130 begins on system startup.
- the motion event manager 130 process 130 next queries the MOTION_EVENT_PROVIDER component category in the Windows Registry to enumerate all motion event providers 132 installed on the system.
- the registry entry of each of the event providers 132 contains startup information indicating if the particular event provider is either a standard in-proc provider or a specialty provider that is injected into a target process to monitor event conditions.
- the motion event manger 130 creates a new instance of each provider 132 . If the event provider 132 is a specialty provider that is injected into a target application process, the event manger 130 will read the target-process information from the provider's registry entry, find the target process, and perform the DLL-injection. If the target process is not active, the motion event manager 130 will continually monitor the creation of new applications, and perform the injection when/if the requested application is launched.
- the motion event manager 130 will send the appropriate initialization information to each provider 132 , including callback information to allow the event providers 132 to post event messages back to the event manager 130 .
- the event provider 132 reads initialize message data and establish the necessary event syncs to monitor the events.
- the initialize message data includes a registry key identifying the location of the event configurations and preferences as last set by the motion event configuration interface 134 or the default installed set.
- This scenario describes the process of injecting a motion event provider DLL into the address space of a target application.
- the first step of this process is for the motion event manager 130 to determine which process into which the motion event provider 132 must be injected based on the registry entry of the provider 132 .
- the next step is for the event manager 130 to install a Windows message hook in the target process. This causes the event provider DLL to be loaded into the target address space of the target process. The event provider DLL has now been loaded into the required process, and will now wait for the “initialize” message from the motion event provider 132 .
- This scenario map describes the process of configuring motion events of each of the motion event providers 132 .
- the user launches the motion event configuration interface 134 from system tray interface of the motion event manager 130 .
- Each event provider object 132 supports a custom visual control 154 that can be used to edit the object's supported events.
- the event configuration interface 134 creates and hosts these visual controls 154 for the user.
- the event provider configuration control 154 when the event provider configuration control 154 is created and initialized, it will receive the location in the Windows Registry 142 of its persisted event data, which will be loaded into the control 154 .
- event provider 132 to configure. Individual events may be mapped to motion actions, and particular events (as well as the entire event provider itself) may be deactivated if desired. As noted above, these event configuration controls 154 may also provide the means to add additional, customized events based on input user parameters (custom text strings, buddy chat names, email messages, etc).
- the event provider configuration control 154 When the user selects an event to configure, the event provider configuration control 154 will defer to the media view control object 156 .
- the media view control object 156 displays all available motion media via a dialog box, allowing the user to make a selection.
- the media view control object 156 returns data back to the event provider configuration control object 154 (including human-readable description text of the event for display as well as a data token which can later be used to identify media selection).
- the configuration control object 154 then persists this information to the Windows Registry 142 .
- FIG. 5 depicted therein is a motion event scenario map. This scenario describes the process of handling a motion event.
- the scenario depicted in FIG. 5 begins whenever an event occurs.
- the occurrence of an event may be caused from a user action, operating system event, or an event situation monitored in a third-party application.
- the event provider 132 then fires a event token associated with this event to the event manager 130 .
- the event token has previously been stored in the registry during the event configuration process. If the provider 132 requires queried data to be returned, the provider 132 will also pass the necessary callback data to the event manager 130 .
- the event manager 130 next receives the event and passes the requested media information to the motion control component 150 .
- the motion control component 150 then executes the specified motion media on the target motion device 122 .
- the motion control component 150 will return the appropriate data.
- the motion event manger 130 will send the data through the specified event provider callback mechanism.
- FIG. 6 Depicted in FIG. 6 is a motion web site scenario map.
- the scenario of FIG. 6 describes how a user may obtain new motion media and motion event providers 132 from the motion web site 136 .
- This process may be started when users visit the motion web site 136 to browse currently available motion event providers 132 and new motion media.
- the reference character 144 a is used to represent a motion media file stored locally by the system 120
- the reference character 144 represents a motion media file stored at a remote location.
- the user selects the desired provider/media download option, and the new software is installed into the motion event manager 130 including the motion control component 150 .
- the motion event configuration interface 134 The next time the motion event configuration interface 134 is launched, the user will be able to configure the new event provider 132 or motion media in the local motion media file 144 a.
- users may download new event providers 132 and motion media directly from within the motion event Configuration dialog interface.
- This configuration dialog will provide the following options to the user: Download new Motion Media and/or Download/install new motion event providers 132 .
- the user or the motion event manager 130 may also check for new versions of currently installed motion media and/or event providers 132 .
- the configuration dialog interface object 134 automatically downloads and installs the new software from the media web site 136 .
- the configuration dialog 134 will automatically update to provide access to the new components and/or media.
- FIG. 7 depicted therein is the system shutdown scenario map. This scenario describes the process of shutting down the exemplary event manager module 130 associated with the motion control component 150 .
- the motion event manager 130 Upon operating system shutdown, the motion event manager 130 will prepare to terminate.
- the event manager 130 next posts a shutdown message to each event provider 132 currently being managed by the manager 130 .
- Specialty event providers 132 that have been injected into external processes may have already finished if the target process has been shutdown. In this case those event providers 132 would have already notified the event manager 130 that they are no longer available.
- Each event provider 132 performs any required shutdown tasks.
- each provider 132 Upon finishing any shutdown tasks, each provider 132 will notify the event manager 132 that the provider 132 is now finished.
- the event manager 130 receives notifications that each of the event providers 132 managed thereby have been shutdown, the event manager 130 itself is now finished.
- FIG. 8 depicted therein is a scenario map illustrating the mapping of text to motion events.
- This scenario generally describes the mapping of text based event situations to motion.
- the first step of this process is for a text based event situation to occur.
- This text could be one or more of the following: (a) a particular sub-string in an Instant Message or the entire message string itself; (b) an Instant Message sent from a target screen or ‘buddy’ name; (c) a text string converted from a speech-to-text engine installed on the user's machine; and/or (d) an email message meeting previously configured criteria (Sent From, Subject, message content, etc).
- a peer-to-peer networked application such as Instant Messenger-type process
- text is entered at a remote source application and sent as a text message to a receiving application.
- the motion event provider 132 monitoring the specific text based event catches the event, and performs any pre-processing of the text required to identify the particular event.
- a DLL functioning as the event provider 132 is injected into the receiving application; the DLL event provider 132 intercepts the message received by the receiving application and treats the received message as an event.
- the event provider 132 will lookup the corresponding motion event token as previously configured. As generally described above, the motion event tokens are pre-loaded upon initialization. In the peer-to-peer example described above, the DLL functioning as the event provider 132 sends the text message as part of the event token to the event manager 130 using a process-to-process communication system as generally described above.
- the event manager 130 determines the type of event represented by the received token.
- the event manager 130 determines that the received event token corresponds to a text event, the event manager 130 next parses the text parameter from the event token. The motion event manager 130 looks up the motion media associated with the event type and event text parameter. The appropriate motion media is then sent to the motion control component 150 for execution on the target motion device 122 as described above with reference to FIG. 5 .
- the event manager 130 uses the motion control component 150 to continually query the target device 122 for state information.
- the control component 150 causes the event manager to ‘create’ a new event (such as a text event) and send it to an event provider 132 .
- the event provider 132 in turn then causes the receiving application to sent a message to a remote peer-to-peer application; again, the receiving and remote peer-to-peer applications may be Instant Messenger compatible applications.
- An example of the use of the present system to verify motion status would be for the event manager 130 to continually or periodically query the target device 122 through the motion control component 150 for status parameters that indicate a fault condition. Once a fault condition occurs, the event manager 130 builds a text message that describes the fault and then sends the text message to a remote application, such as an Instant Messenger user, using process-to-process communication system and the peer-to-peer networked application.
- a remote application such as an Instant Messenger user
- Table A describes the interface specifications for components of the exemplary motion control system 120 described above using the exemplary motion control component 150 .
- the Windows Registry 142 is used to persist event management with motion control configuration data.
- Data associated with the motion event providers 132 is persisted to the Windows Registry 142 primarily to accommodate event provider DLLs that need to be injected into a target process, an environment where those DLLs may not be able to rely on standard COM storage alternatives.
- the motion event manager 130 when the motion event manager 130 initializes an event provider, the provider will receive a location in the registry where it should read its previously configured event data.
- the event configuration controls 156 of the event providers 132 receive the registry location, and will persist configuration changes to that location.
- Event providers will persist both standard (hard coded) and custom events to their registry storage location. Associated with each event will be the configured motion event token data, which the provider will use when firing event notifications back to the motion event manager 130 .
- the motion event manager 130 manages all registry locations for the event provider objects.
- the event manager provides a mechanism to support different event schemes. This allows configurations unique for several different users, situations, or motion devices.
- the event manager 130 When a new scheme is selected via the motion event configuration interface 134 , the event manager 130 will pass the new scheme registry location to each event provider object 132 , allowing access to the new scheme data.
- Each scheme will be located in a unique sub key under the primary event manager registry location.
- the user interface components 154 and 156 of the system 120 may be implemented in many different forms.
- the motion event configuration control 154 is used to configure all motion event providers 132 installed on the system, as well as to provide access to the motion web site 136 where new motion media and motion providers may be downloaded and installed.
- the interface of the media creation tool 138 is a preferably graphical representation of the motion device or system, where simple drag-drop, click, and record operations will facilitate the creating and modification of motion media.
- the system 120 is designed to be easily extendible via new motion event provider and motion media components.
- the system 120 is also capable of supporting any number of additional event sources with the addition of new motion event providers 132 by registering these new providers with the system 120 .
- These event providers 132 can link to virtually any event source to a target system 122 .
- the motion media formats can be modified and extended without requiring changes to any event provider objects.
- a XMCMediaCtrl object proxies the raw motion media format to the event providers. Accordingly, once the XMCMediaCtrl component is updated to handle any new media formats, the event providers 132 may, by design, make use of the changes.
- a motion program or media set may be streamed to the device 122 through the system 120 .
- Whether or not and how the media plays may be controlled by captured events. For example, a media player may fire events based on different musical notes or tones. When such events are received, one media stream may be selected over another, thus causing the motion device 122 to perform different actions. This may also occur with the standard motion programs described above.
- Very large motion programs may be downloaded in partial form and then either downloaded in full over time or as certain specified events occur in the system.
- single motion operations may also be supported in which a specified event causes a single motion operation to take place immediately.
- a specified event causes a single motion operation to take place immediately.
- One example of this would be an event that causes movement of one axis in the clockwise direction.
- FIG. 9 depicted therein is a second example of a motion control system 220 constructed in accordance with, and embodying, the principles of the present invention.
- the motion control system 220 comprises a machine platform 222 and an event notification system 224 .
- the machine platform 222 may be implemented using a controller neutral platform technology as described, for example, in U.S. Pat. Nos. 5,691,897, 5,867,385, 6,209,037, 6,480,896, 6,513,058, 6,516,236, 6,542,925 and/or 6,571,141, which are incorporated herein by reference.
- the machine platform 222 is or may be any motion control system, whether controller dependent or controller neutral, that comprises a machine converts motion commands into movement of an object.
- controller refers to the hardware or software that contains the logic used to run the machine. Typically the controller one or more of a PLC, CNC Controller, or Motion Controller. The controller contains the main control loop used to position, monitor, or otherwise direct a machine to carry out useful automated tasks.
- a machine is used herein to refer to a physical machine or device asset used to perform a specified task.
- a machine may be a CNC Mill used to shape metal, a pick-n-place machine used to position parts on a circuit board, a robotic machine used to perform surgery, a medical data input device used to collect the vitals from a human being (i.e. blood glucose meter, asthma meter, etc), a gaming device used when playing a game, a robotic toy, an animatronics figure, a robotic machine used to deliver goods to a warehouse or to people, an automobile, truck or farm vehicle, a boat or ship that maneuvers in water, a airplane, jet, helicopter and/or spacecraft.
- a machine may be a CNC Mill used to shape metal, a pick-n-place machine used to position parts on a circuit board, a robotic machine used to perform surgery, a medical data input device used to collect the vitals from a human being (i.e. blood glucose meter, asthma meter, etc), a gaming device used
- machine Any self powered machine or device (mobile or not) that is either directly controlled by humans or automatically controlled via a computer based system falls within the definition of “machine” as used herein.
- device as used herein is essentially synonymous with the term “machine,” but may be used in reference to a machine with a relatively small footprint.
- the example event notification system 224 comprises a main event handler 230 , one or more event handler applications 232 , and one or more event handler property pages 234 .
- the example main event handler 230 comprises a data queue 236 .
- the main event handler 230 is a component that is in communication with the machine platform 222 such that the main event handler 230 receives one or more events from the machine platform 222 .
- the example data queue 236 within the main event handler 230 is a standard data queue that employs first-in/last-out technology.
- the data queue 236 may be implemented as a priority queue that allows the items in the queue to be organized based on given priorities associated with the data contents of each item in the queue.
- the data queue 236 may optionally use a timing scheme that ensures that all items within the queue are processed within a given time frame, such that no items within the queue are ‘starved-out’ when a high frequency of higher priority items are received.
- the event handler application 232 is used to configure and run the main event handler 230 .
- the example event handler application 232 is a Windows System Tray application.
- the event handler application 232 is optional, and the main event handler 230 may be run and configured using other systems and methods.
- the event handler property page 234 is used to configure the settings of the main event handler 230 by presenting a user interface that allows the user to see the settings of the main event handler 230 and/or to change these settings.
- the main event handler 230 is also in communication with one or more possible event destinations such as an upstream event handler 240 and/or a downstream event handler 242 .
- the example upstream event handler 240 is a module similar to the main event handler 230 that serves data to the main event handler 230 .
- the example downstream event handler 242 is also a module similar to the main event handler 230 , but one that receives data from the main event handler 230 .
- the main event handler 230 is a downstream event client.
- the main event handler 230 is an upstream event client.
- the main event handler 230 may also be in communication with one or more event destinations through an intermediate destination such as a shared memory system 250 , a memory queue 252 , and/or a network protocol 254 .
- the shared memory system 250 is a block of memory that is accessible to different modules and/or applications.
- the example memory queue 252 uses Microsoft Message Queue (MSMQ) technology or a similar technology. MSMQ allows for communication with other modules and/or applications using a delayed messaging technology called Message Queuing.
- MSMQ Microsoft Message Queue
- the example network protocol 254 is formed using TCP/IP or UDP broadcast protocols as a mechanism of sending output data to another target.
- the TCP/IP protocol specifies specific data target(s), and the UDP protocol broadcasts data to all nodes on a given network.
- the main event handler 230 delegates one or more events received from the machine platform 222 to one or more event destinations such as the upstream event handler 240 and/or the downstream event handler 242 .
- the main event handler 230 may delegate one or more events received from the machine platform 222 to additional event destinations using one or more of the intermediate destinations such as the shared memory system 250 , the memory queue 252 , and/or the network protocol 254 .
- the main event handler 230 may further be in communication with an alternate event source such as a data transport system 260 .
- the data transport system may be implemented using the data router technology described in co-pending U.S. patent application Ser. No. 10/844,025, which is incorporated herein by reference.
- the data transport system 260 routes data outputs to various output sources, one of which may be the main event handler 230 .
- the main event handler 230 may also be configured to delegate events from the data transport system 260 to the event destinations such as the upstream client 240 and/or the downstream event handler 242 and/or to intermediate destinations such as the shared memory system 250 , the memory queue 252 , and/or the network protocol 254 .
- the event notification system 224 may use an event handler, such as the main event handler 230 , which is internally configured to handle communications with the event destinations and/or intermediate destinations as shown in FIG. 9 .
- the motion control system 320 may use an event notification system 224 a having a modular main event handler 230 a as depicted in FIG. 10 .
- the modular event handler 230 a is a more modular design where each output is modularized, thus giving the event handler 230 a the capability to select from a list of destination modules either programmatically or through a user interface.
- the example modular main event handler 230 a further comprises at least one event communication component 270 configured to handle the details of communicating with one or more of the event destinations and intermediate destinations.
- FIG. 10 shows that the modular main event handler 230 a is in communication with the following event communication components: a component 270 a configured to communicate using e-mail or SMTP protocols; a component 270 b configured to access shared memory such as the shared memory system 250 ; a component 270 c configured to communicate with a network protocol such as the network protocol 254 ; a component 270 d configured to communicate with a memory queue such as the memory queue 252 ; a component 270 e configured to communicate with a peer-to-peer communication system such as Instant Messenger; a component 270 f configured to communicate using XML messaging; a component 270 g configured to communicate using envelope based communication services such as SOAP; and/or other communications components 270 h.
- event communication components a component 270 a configured to communicate using e-mail or SM
- More than one event communication component 270 of the same type may be used simultaneously.
- the event handler 230 a may use two event client components configured to communicate with a network protocol where each component is capable of sending data to a different destination network address.
- FIG. 11 depicts the steps that take place when configuring the system 220 using an application such as the event handler application 301 described above. Initially, in a first step the event handler application 232 queries the event handler 230 for its event handler property page or pages 234 . Once received, the event handler property page or pages 234 are displayed to the user. In a second step, configuration changes are saved to the main event handler 230 by changing the properties and/or calling methods of the event handler 230 .
- FIG. 12 depicts the steps that occur when configuring the event handler 230 from another component.
- the other component such as the data transport 260 , queries the event handler 230 for its event handler property page(s) 234 , which, once received, are displayed to the user. For example, this may occur via a property page of the calling component.
- configuration changes are saved to the event handler 230 by changing the properties of the event handler 230 and/or calling methods on the event handler 230 .
- each output may be enabled or disabled. Later, when processing data, data is only sent to each enabled output.
- FIG. 13 depicts the steps that take place when initializing the event handler 230 .
- a component such as the data transport 260 and/or the event handler application 232 , directs the event handler 230 to initialize itself.
- the event handler 230 uses its internal properties, which were previously configured during the configuration stage, to connect to a machine platform 222 or an upstream event client 240 , and subscribe to the data items specified in the configuration data.
- the data items specified in the configuration data must be data that are published by the machine platform 222 , or failures may occur.
- the term “publish” refers to a method of receiving data updates where the client subscribes to data published by the server.
- a server may have three data items available for subscriptions: A, B, C.
- the client may then subscribe to any of these data items upon which the client may receive data updates based upon certain criteria such as the data value of the subscribed data item changing, a time period passing, or some other event occurring in the system such as a trigger variable firing, etc.
- trigger variable refers to variable or data item that causes the registered actions to be carried out when the variable or data item's event conditions are met.
- FIG. 14 depicts the steps that take place when processing events.
- the event is received from an upstream component such as the machine platform 222 and/or an upstream event handler 240 that is daisy chained to the main event handler 230 .
- the data Upon receiving the event, the data is optionally placed at the back of the internal data queue 236 . If a queue is not used, the data is immediately sent to all event destinations, such as shared memory system 250 or the network protocol 254 , that are in an enabled state for that event. If the internal data queue 236 is used, data items are pulled off the data queue according to the rules for that queue and sent to all outputs that are in an enabled state for that event. As described above, the data queue 236 may be a first-in/last-out queue, a priority queue, and/or a queue implementing a timing scheme.
- the event handler 230 may also process commands via API calls to one of its interfaces.
- the data transport 260 may direct the event handler 230 to send data to an event destination by calling an API of the event handler 230 .
- FIG. 15 depicts the steps that occur when processing a command using API calls.
- the remote component such as the data transport 260 may call an event handler API through which the data is passed.
- the API may optionally place the data into an internal data queue 236 . If a data queue is not used, the data is passed directly to all outputs, such as the shared memory system 250 or the network protocol 254 , that are in an enabled state for a given event.
- the main event handler 230 may be daisy chained with one or more upstream event handlers 240 and/or one or more downstream event handlers 242 .
- data is received from upstream event handlers 240 and/or sent to downstream event handlers 242 .
- FIG. 16 depicts the steps that occur when processing events or commands in a daisy chained configuration.
- an event handler is connected upstream to the main event handler 230 , the data is received from that upstream event handler 240 as an event and/or as an API call. If an upstream event handler 240 is not used, data may be received in the normal manner either via an event or API call. Next, upon receiving the data as an event and/or as an API call, the data may be placed at the back of an internal data queue 236 if used. If a data queue is not used, the data is sent directly to all outputs (such as shared memory system 250 or network protocol 254 ) that are in an enabled state.
- outputs such as shared memory system 250 or network protocol 254
- the data queue 236 when using the internal data queue 236 , the data is pulled from the data queue and sent to all enabled outputs.
- the data queue may be a first-in/last-out queue, a priority queue, and/or a queue implementing a timing scheme.
- the data is sent to zero, one, or more event destinations previously configured for this output in the case of a TCP/IP network.
- the data may be sent as a UDP broadcast to all nodes on a network or group of networks.
- TCP/IP may also be used to send the data via a tunneling mechanism, such as is used within a Virtual Private Network (like those implemented with Microsoft RRAS), from the current event handler 230 to another event handler 230 (or even to a group of event handlers 230 ), where the receiving component receives the TCP/IP or UDP data and then translates it into an event or API input.
- a message queue 252 such as a MSMQ, event destination is used and enabled, the data is sent via the message queue 252 to another application or component, or even to another event handler 230 (or group of components).
- the main event handler 230 sends data directly to any such event handlers 24 - and/or 242 .
- a downstream event handler 242 may be configured to communicate with the upstream event handler 230 via the shared memory 306 and/or other standard synchronization events such as the event object supported within Win32.
- the downstream event handler 242 may pass configuration information on to the main event handler 230 .
- any downstream event handler will notify any upstream event handler of all data items that are to be subscribed.
- the subscribing data may be continually passed along the daisy chain to modify any upstream event handlers and/or directly notify the machine platform 222 , if it is connected directly to the machine platform 222 .
- the event handler 230 is preferably a modular system made up of a set of components (i.e. each component is based on a component technology such as OLE/COM from Microsoft Corporation).
- each component may use a separate ‘parallel’ ActiveX component and/or a property page component to implement all user interface aspects of the main component.
- Each ActiveX and/or property page component may be implemented either within the main component module or separately in its own module. Bundling each object within one module is not required as they may be located at any location (i.e. across a network, and so forth), but doing so may optimize all communication between modules. How and where components are implemented is a logistical decision. Once components are built and deployed to the field, it is difficult to update a single component if all components are implemented within a single DLL or EXE module.
- FIG. 18 depicts an example of the interfaces exposed by the example event handler components.
- all components making up the system 220 at a minimum implement a single interface—the IXMCDirect interface.
- the event handler components 230 , 240 , and 242 implement the IXMCDirectSink interface as well.
- the event handler components 230 , 240 , and 242 may optionally implement the IXMCaCNCEventDataSink interface if they are to receive events directly from the machine platform 222 .
- the IXMCDirect, IXMCDirectSink, and IXMCaCNCEventDataSink interfaces will be described in further detail below.
- OLE Categories are used to determine how many components fall into a certain group of components.
- components used to form the event handler components use what will be referred to herein as the XMC Data Router components.
- the XMC Data Router components are general data router components support the general read, write, and configure API.
- the IXMCDirect interface is used for most communications between all components making up the event handler 230 .
- the following methods make up this interface (as specified in the standard OLE/COM IDL format).
- the IXMCDirect interface is made up of the following functions.
- the IXMCDirect::GetProperty method is used to query the property corresponding to the property name ‘pszPropName’.
- Each component defines the properties that it supports.
- This IXMCDirect::SetProperty method is used to set a property in the component corresponding to the ‘pszPropName’ property. For the set of properties supported by the component, see the specific component description.
- the IXMCDirect::InvokeMethod method is used to call a specific method implemented by the component. For more information on the methods supported, see the description of the specific component.
- the IXMCDirectSink interface is an event reception point on which one component can send event data to another.
- the component implementing this interface is the event receiver, and the event source calls the interface passing to it event data.
- the IXMCDirectSink interface is made up of the following functions:
- the IXMCDirectSink::OnEvent method is called by the event source and passed the event data in a SAFEARRAY form for easy marshalling across process boundaries.
- the IXMCDirectSink::OnError method is called by the event source when an error occurs and passed the event error data in a SAFEARRAY form for easy marshalling across process boundaries.
- the event handler 230 In order to receive events directly from the machine platform 222 , the event handler 230 also supports the IXMCaCNCEventDataSink interface as specified in the machine platform 222 product sold by ROY-G-BIV Corporation.
- IXMCaCNCEventDataSink IDispatch ⁇ [id(1), helpstring(“method OnData”)] HRESULT OnData( [in] long IConnectionCookie, [in] long ISubscriptionCookie, [in] long IDataCookie, [in] BSTR bstrName, [in,out] SAFEARRAY(VARIANT)* pvData, [in] double dfTimeStamp ); [id(2), helpstring(“method OnError”)] HRESULT OnError( [in] long IConnectionCookie, [in] long ISubscriptionCookie, [in] long IDataCookie, [in] BSTR bstrName, [in]
- FIG. 19 of the drawing depicted there in is an example of the IXMCaCNCEventDataSink OLE Interface.
- OnData This event is called on the client application each time the event conditions are met for a given enabled subscription.
- OnError This event is called on the client application each time an error occurs while processing a subscription.
- the OnData event is called each time the event condition for an enabled subscription is met for a subscription configured by a client application.
- Deadlock can occur when running in multi-application mode and calls to other XMC API are made from within this event hander or another event raised by this event handler. To avoid this situation, applications that implement this method should copy all data from this method into a temporary buffer and immediately return without calling other XMC API.
- OnError event is called each time an error occurs for a subscription configured by a client application.
- Applications that implement this method should immediately copy the data received in a temporary buffer and or array and immediately return so as to not cause deadlock within their application.
- Deadlock can occur when running in multi-application mode and calls to other XMC API are made from within this event handler or another event raised by this event handler.
- This section describes the general component properties of each property supported by the event handler 230 component.
- TARGETMACHINE rgData[0] - (string); name of the target machine for which the XMC Event Client component is to connect up to and receive data from.
- OPTIONS rgData[0] - (DWORD); options describing how the XMC Event Client is to operate. The following options are supported.
- OF_AUTOLOAD_ENABLED - when specified, the component automatically loads the configuration settings specified in the configuration file specified in the CONFIGFILE property.
- OF_AUTOSTART_ENABLED - when specified, the component automatically connects and starts monitoring data items that are specified.
- OF_MAPVARIABLES_ENABLED - when specified, the variables listed in the variable mapping file specified in VARMAPFILE property are loaded.
- OF_QUEUE_EVENT_ENABLED when specified, all data received through an event are placed at the back of the data queue.
- OF_QUEUE_API_CALLS_ENABLED when specified, all data received on the Write API are placed at the back of the data queue.
- OF_WAIT_FOR_DATA_RECEIVED when specified, the component waits until an external application signals the data ready event before placing more data in the output(s).
- OF_DELETE_OLD_QUEUE_ITEMS - when specified, data items within the data queue that have been in the data queue for a time period longer than the amount specified in the DATAOLDTIMEOUT property are purged from the data queue.
- OF_COLLECT_DATA_ALWAYS - when specified, data items are subscribed in such a way that updates are always sent, even when the data items does not change.
- QUEUEMAXSIZE rgData[0] - DWORD
- DATARECEIVEDTIMEOUT rgData[0] - DWORD
- DATAOLDTIMEOUT rgData[0] - (DWORD) specifies how long data items are allowed to remain in the data queue before being purged.
- the XMC_DE_BROWSE_GET_COUNT method returns the number of data items in the browse set supported by the component.
- Index 8021 Data In rgData[0] - (number) DWORD, maximum number of elements to collect. Data Out rgData[0] - (number) number of elements collected, total number of elements will equal (rgData[0] * 2 + 1). rgData[1] - (string) name of the first browse element. rgData[2] - (number) adt of the first browse element. rgData[1 + n * 2] - (string) name of the n'th browse element. rgData[2 + n * 2] - (number) adt of the n'th browse element.
- the XMC_DE_BROWSE_GET_ITEMS method returns the number of data items in the browse set supported by the component.
- rgData[0] - (number) DWORD type of component.
- the type of component is a value that is server specific. For component type information, see the description for this method under each server's description.
- rgData[1] - (string) LPTSTR component class id as an ASCII string. Data Out None.
- the XMC_DE_SYSTEM_CONNECT_CMPNT method is used to connect one server to another so that they may interact with one another.
- rgData[0] - (number) DWORD type of component.
- the type of component is a value that is server specific. For component type information, see the description for this method under each server's description.
- rgData[1] - (string) LPTSTR component class id as an ASCII string. Data Out None.
- the XMC_DE_SYSTEM_DISCONNECT_CMPNT method is used to disconnect one server to another so that they stop interacting with one another.
- Index 8063 Data In rgData[0] - (number) DWORD, number of data items input. rgData[1 + n * 2] - (string) LPCTSTR, name of the data item input. rgData[2 + n * 2] - (number or string), value of the data item. Data Out rgData[0] - (number) DWORD, number of data items output. rgData[1 + n * 2] - (string) LPCTSTR, name of the data item output. rgData[2 + n * 2] - (number) value of the data item.
- the XMC_DE_DATA_PROCESS method is called by a client to process data where a data set is input, processed in some way by the server, and then the resulting data is returned as output.
- Index 8062 Data In rgData[0] - (number) DWORD, flag describing the type of data to be returned when processing data. The following flags are supported: XMC_DE_READ_DATA_FLAG_TIMESTAMP - requests that the time stamp recorded when processing the data is returned. NOTE: by default, the data item value is always returned. Data None. Out
- the XMC_DE_DATA_PROCESS_CONFIGURE method is used to configure what type of data is returned when processing a given data item. For example in the server may be configured to return the minimal amount of data on each read (i.e. just the data item value), or the server may be requested to return more substantial data.
- Index 8061 Data In rgData[0] - (string) LPCTSTR, name of the data item to read. Data Out rgData[0] - (number or string), data item value. rgData[1] - (OPTIONAL number) DWORD, data item time- stamp as a system time value. NOTE: Since the last items are optional, only those items specified when configuring the data to receive are actually sent.
- the XMC_DE_DATA_READ method is called by a client application to poll for data from the server.
- the term “poll” refers to the process of continually reading a data item so that the most recent value of the data is always on hand.
- Index 8060 Data In rgData[0] - (number) DWORD, flag describing the type of data to be returned on each read. The following flags are supported: XMC_DE_READ_DATA_FLAG_TIMESTAMP - requests that the time stamp recorded when reading the data is returned. NOTE: by default, the data item value is always returned. Data None. Out
- the XMC_DE_DATA_READ_CONFIGURE method is used to configure what type of data is returned when reading a given data item. For example in the server may be configured to return the minimal amount of data on each read (i.e. just the data item value), or the server may be requested to return more substantial data.
- Index 8064 Data In rgData[0] - (number) DWORD, number of data items. rgData[1 + n * 2] - (string) LPCTSTR, name of the data item. rgData[2 + n * 2] - (number or string), value of the data item. Data Out None.
- the XMC_DE_DATA WRITE method is used to write data to a server.
- the XMC_DE_EVENT ENABLE method enables/disables a previously subscribed data item in the subscription list maintained by the server. Only enabled subscriptions actually fire.
- rgData[1] - (number or string) data item value.
- rgData[2] - (OPTIONAL number) DWORD data item time- stamp as a system time value.
- rgData[3] - (OPTIONAL string) LPSTR data item ASCII text name.
- rgData[4] - (OPTIONAL number) DWORD data item unique cookie.
- rgData[0] - (number) DWORD subscription cookie.
- rgData[1] - (number or string) data item value.
- rgData[2] - (string) LPSTR data item name. Data Out None.
- the XMC_DE_EVENT_RECEIVE_DATA method is called by the server (and implemented by the client) when each subscribed event fires.
- Index 8044 Data In rgData[0] - (number) DWORD, flag describing the type of data to be returned on each event. The following flags are supported: XMC_DE_EVENT_DATA_FLAG_TIMESTAMP - requests that the time stamp recorded when reading the data is returned. XMC_DE_EVENT_DATA_FLAG_NAME - requests that the data items ASCII text name be returned. XMC_DE_EVENT_DATA_FLAG_DATA_COOKIE - requests that the unique data item cookie corresponding to the read made for the data item be returned. NOTE: by default, the subscription cookie and data item value are always returned. Data Out None.
- the XMC_DE_EVENT_RECEIVE_DATA_CONFIGURE method is used to configure what type of data is returned on each event that is fired. For example in the server may be configured to send the minimal amount of data on each event (i.e. subscription cookie and data item value), or the server may be requested to return more substantial data.
- Index 2890 Data rgData[0] - (number) DWORD flags describing the initial In state of the subscription. The following flags are supported: XMC_DE_EVENT_FLAG_ENABLED - subscription is immediately enabled upon subscription. XMC_DE_EVENT_FLAG_DISABLED - subscription is disabled upon making the subscription. The Enable function must be called to enable the subscription.
- rgData[1] - (number) DWORD number of subscription criteria rules.
- rgData[2 + (2 * n)] - (number) DWORD event condition type where the following types are supported: XMC_CNC_EVENTCONDITION_DATA_CHANGE - any data changes in the data type above will trigger the event.
- the XMC_DE_EVENT_SUBSCRIBE method subscribes to a given data item activating the event interface when the subscription criteria are met for the data item. All subscribing components must use the IXMCDirect interface to receive events received from the server for which they are subscribed.
- the XMC_DE_EVENT_UNSUBSCRIBE method removes a previously subscribed data item from the subscription list maintained by the server.
- the XMC_DE_SYSTEM_INITIALIZEHW method is used to initialize any hardware systems associated with the component.
- the XMC_DE_SYSTEM_SHUTDOWNHW method is used to shutdown any hardware systems associated with the component.
- the event handler 230 component implements the following general methods listed in the General Component Methods section above.
- the following methods have special notes for this component.
- the XMC_DE_EVENT_SUBSCRIBE method is only needed when daisy chaining components together.
- the XMC_DE_EVENT_UNSUBSCRIBE method is only needed when daisy chaining components together.
- the example property page depicted in FIG. 19 allows the user to set-up the connection settings used to connect to the target machine from which data will be received.
- this property page allows the user to configure how the component is connected and starts-up when it is first run.
- connection and start-up property page 320 As shown in FIG. 19 , the following user interface elements form the connection and start-up property page 320 .
- a “target machine” field 322 identifies the target machine 222 from which data is to be received using the TARGETMACHINE method.
- a “connect” button 324 tests the connection with the target machine using a CONNECT method.
- a “disconnect” button 326 disconnects the system 224 from the target machine 222 using the DISCONNECT method.
- a “map variables” check box 328 specifies whether or not to load mapped variables from a file when connecting using OPTIONS, (OF_MAPVARIABLES_ENABLED), and VARMAPFILE properties. When checked, a dialog appears allowing the user to select the file to load mapped variables from.
- An “enable auto load” check box 330 specifies whether or not the auto load feature should be enabled and, when enabled, from which file to load the settings from as identified in a “file” field 332 using OPTIONS, (OF_AUTOLOAD_ENABLED), CONFIGFILE properties.
- An “enable auto start” check box 334 specifies whether or not to enable auto start using OPTIONS (OF_AUTOSTART_ENABLED) properties.
- An event monitoring property page 340 depicted in FIG. 20 allows the user to configure which variables are to be monitored.
- the event monitoring property page 340 comprises the following interface elements.
- a “variables” box 342 contains a list of all variables that are available for monitoring.
- a “test” button 344 directs the application to test a selected (highlighted) variable by reading it using a READ method.
- An “attributes” 346 button retrieves the attributes of the selected (highlighted) variable using the READ(‘attrib’) method.
- a “variables” (to monitor) box 350 contains a list of all variables that have been selected for monitoring using VAR_MONITOR_COUNT and VAR_MONITOR_properties.
- a first “add . . . ” button 352 directs the event handler 330 to add a variable from the “variable” list in the box 342 to the “variables (to monitor)” list in the box 350 .
- a first “remove” button 354 directs the event handler 330 to remove the selected variable from the “variables (to monitor)” list in the box 350 .
- pressing the first “remove” button 354 directs the event handler 330 to remove all variables from the “variables (to monitor)” list box 350 .
- a “variables (to read)” box 360 contains a list of all variables that have been selected for reading using VAR_READ_COUNT and VAR_READ_properties.
- a second “add . . . ” button 362 directs the event handler 330 to add a variable from the “variable” list in the box 342 to the “variables (to read)” list in the box 360 .
- a second “remove” button 354 directs the event handler 330 to remove the selected variable from the “variables (to read)” list in the box 360 .
- pressing the second “remove” button 364 directs the event handler 330 to remove all variables from the “variables (to read)” list box 360 .
- the data collection property page 370 comprises the following user interface elements.
- check box 372 and associated edit field 374 specify the maximum number of items to be placed in the optional data queue 236 using the following properties: OPTIONS (OF_QUEUE_API_CALLS_ENABLED), OPTIONS (OF_QUEUE_EVENTS_ENABLED), and QUEUEMAXSIZE.
- a “delete old items after:” check box 380 and associated edit field 372 specify the amount of time that data items may remain in the queue after which they are purged, using the following properties: OPTIONS (OF_DELETE_OLD_QUEUE_ITEMS) and DATAOLDTIMEOUT method.
- the “collect data always” check box 384 specifies whether or not data should always be collected, even when the data does not change, using the following properties: OPTIONS (OP_COLELCT_DATA_ALWAYS).
- This Appendix A contains the definitions of all special types used by the methods and properties of each component making up the example XMC Program Engine system that may form a part of the present invention.
- All methods exposed by each component in the XMC Program Engine system use the standard XMC parameters set to describe data used to set and query properties as well as invoke methods.
- the standard parameters are in the following format:
- Each element in the rgData array corresponds to a parameter, with the first element in the array corresponding to the first parameter.
- the XMC_PARAM_DATA structure can contain either a numerical or a string value and is defined as follows:
- the ‘adt’ member of the XMC_PARAM_DATA structure describes the data contained within the XMC_PARAM_DATA structure. The values are described below:
- LNG_PARAM_DATATYPE Description LNG_ADT_NUMBER Use this value when passing a numerical value via the ‘adt’ member of the XMC_PARAM_DATA structure.
- LNG_ADT_STAT_STRING Use this value when passing a static string value via the ‘psz’ member of the XMC_PARAM_DATA structure. Static strings do not need to be freed from memory.
- LNG_ADT_MEM_STRING Use this value when passing a string value via the ‘psz’ member of the XMC_PARAM_DATA structure.
- LNG_ADT_MEM_STRING denotes that the string must be freed from memory during cleanup.
- LNG_ADT_NOP This value is used to ignore items within the XMC_PARAM_DATA array. When specifies, this parameter is not used.
- any non-zero value is considered TRUE, whereas a zero value is considered FALSE.
Landscapes
- Engineering & Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Physics & Mathematics (AREA)
- Software Systems (AREA)
- Computer Security & Cryptography (AREA)
- Theoretical Computer Science (AREA)
- General Engineering & Computer Science (AREA)
- Automation & Control Theory (AREA)
- Signal Processing (AREA)
- Manufacturing & Machinery (AREA)
- Multimedia (AREA)
- Human Computer Interaction (AREA)
- Computer Networks & Wireless Communication (AREA)
- User Interface Of Digital Computer (AREA)
- Stored Programmes (AREA)
Abstract
A motion control system comprising a machine platform, at least one event destination, and an event handler. The machine platform carries out automated tasks and generates events. The event handler is configurable to receive at least one event from the machine platform and send the at least one event to the at least one event destination.
Description
- This application (Attorney's Ref. No. P217272) is a continuation of U.S. patent application Ser. No. 12/896,750 filed on Oct. 1, 2010.
- U.S. patent application Ser. No. 12/896,750 is a continuation of U.S. patent application Ser. No. 11/728,801 filed on Mar. 26, 2007, now U.S. Pat. No. 7,904,194 which issued on Mar. 8, 2011.
- U.S. patent application Ser. No. 11/728,801 is a continuation of U.S. patent application Ser. No. 11/368,231 filed on Mar. 3, 2006, now abandoned, which claims benefit and/or priority of U.S. Provisional Application Ser. No. 60/658,746 filed on Mar. 3, 2005.
- U.S. patent application Ser. No. 11/368,231 is a continuation-in-part of U.S. patent application Ser. No. 10/074,577 filed on Feb. 11, 2002, now U.S. Pat. No. 7,031,798, which issued on Apr. 18, 2006, and which claims benefit and/or priority of U.S. Provisional Application Ser. No. 60/267,645 filed on Feb. 9, 2001.
- The contents of all related applications listed above are incorporated herein by reference.
- The present invention relates to motion control systems and, more specifically, to an event management system optimized for the processing and distribution of events associated with a motion control device.
- Electromechanical systems are used in numerous environments to translate electrical signals into mechanical movement. As examples, factory automation systems, toys, appliances, and the like all may use one or more electromechanical transducers that move in response to electrical control signals.
- Typically, an application programmer familiar with a specific environment creates an application program defining a desired sequence of movements. U.S. Pat. Nos. 5,691,897, 5,867,385, and 6,209,037 to Brown et al. disclose systems and methods for generating, processing, and/or distributing control commands to one or more motion control devices based on such an application program.
- The present invention may be embodied as a part of an overall motion control system as described in the Brown et al. patents and will be described herein in that context. However, as described below, the principles of the present invention may have broader application to other motion control systems and methods, and the scope of the present invention should be determined by the claims appended hereto and not the following detailed description.
- The present invention may be embodied as a motion control system comprising a machine platform, at least one event destination, and an event handler. The machine platform carries out automated tasks and generates events. The event handler is configurable to receive at least one event from the machine platform and send the at least one event to the at least one event destination.
-
FIG. 1 is a module interaction map depicting a motion control system incorporating an event management system of the present invention; -
FIG. 2 is a scenario map depicting the startup and initialization of the system ofFIG. 1 ; -
FIG. 3 is a scenario map depicting the process of injecting a motion event provider DLL into the address space of a target application; -
FIG. 4 is a scenario map depicting the process of configuring motion events provided by each of one or more motion event providers 132; -
FIG. 5 is a scenario map depicting the process of handling a motion event; -
FIG. 6 is a scenario map depicting how a user may obtain new motion media and motion event providers 132 from themotion web site 136; -
FIG. 7 is a scenario map depicting shut down of the system ofFIG. 1 ; -
FIG. 8 is a scenario map depicting the mapping of text to motion events; -
FIG. 9 is a module interaction map depicting interactions of modules forming another example motion control system of the present invention; -
FIG. 10 is a module interaction map depicting an event handling system constructed using a modular output model; -
FIG. 11 is a use case depicting the configuration of an event handling component from an application; -
FIG. 12 is a use case depicting the configuration of an event handling component from another component; -
FIG. 13 is a use case depicting the initialization of an event handling component; -
FIG. 14 is a use case depicting the manner in which the event handling component processes events; -
FIG. 15 is a use case depicting the manner in which the event handling component processes commands; -
FIG. 16 is a use case depicting the manner in which events and commands are processed in a daisy chain of event handling components; -
FIG. 17 is a use case depicting the manner in which an event handling component passes configuration data to other event handling components in a daisy chain configuration; -
FIG. 18 is a module layout depicting the interfaces exposed by the event handling component; -
FIG. 19 depicts an example a user interface screen used to configure connection and start-up settings; -
FIG. 20 depicts an example user interface screen used to configure event monitoring settings; and -
FIG. 21 depicts an example user interface screen used to configure data collection settings. - Referring initially to
FIG. 1 , depicted therein is amotion control system 120 constructed in accordance with, and embodying, the principles of the present invention. Themotion control system 120 is an event-based system used to control, configure, and query one or more motion based devices or machines such as indicated byreference character 122 in the drawing. The motion based devices ormachines 122 will be referred to herein as the target device. - In the context of the motion control systems described herein, data is often associated with events. The term “data” (or data items) includes any numeric or string data values collected from a target machine or device in an analog or digital format that is made compatible for computer systems. For example, BIT, BYTE, WORD, DWORD, LONG, REAL, DOUBLE, FLOAT, STRING, ASCII STRING are a few data types that represent data items. Data may be collected from data sources by reading register values on the data source, reading shared memory provided by the data source, sending commands to the data source for which a data response is given containing the data requested, reading variables provided by the data source, reading and writing to variables in a sequence necessary to produce data values, querying data using a proprietary or standard data protocol, calling a function provided by the target data source, etc. The term “variable” as used herein refers to a data item that has both a name and optionally associated data. A data item may be a function call, a named data variable, a tag within a database, or the like. The terms “variable” and “data item” are used interchangeably to refer to a data point that includes one or more atomic data elements.
- In the following discussion, the components or objects that form the
motion control system 120 and the basic operation of thesystem 120 will first be described. After that will follow a discussion of the interaction between those objects and several detailed scenarios of typical actions of thissystem 120. - Referring initially to
FIG. 1 of the drawing, it can be seen that themotion control system 120 comprises the motion based machine ordevice 122, amotion event manager 130, one or more motion event provider objects 132, amotion event interface 134, amotion web site 136, and amedia creation tool 138. - The
system 120 is adapted to be run on a general purpose computer platform comprising computer hardware and anoperating system 140. Theexemplary operating system 140 is a Windows variant and comprises aregistry 142. - The
web site 136 andmedia creation tool 138 provide access to one or more motion media files 144. Themotion media files 144 contain what will be referred to herein as motion media. - The term “motion media” includes motion scripts, motion application programs, and/or individual motion instructions capable of causing the
target device 122 to perform a desired motion operation comprising a discrete movement or sequence of movements. - The motion media comprises what will be referred to as motion commands. The term “motion commands” will be used herein to refer to both control commands and media commands associated with a desired motion operation. The term “control commands” as used herein refers to device-specific commands that may be directly run by a target device to obtain a desired motion operation.
- The term “media commands” used herein refers to machine independent instructions that generically define a desired motion operation. Normally, media commands are converted into control commands before the target device executes the desired motion operation corresponding to a particular media command or set of media commands.
- The term “application program” will be used to refer to a set of control and/or media commands associated with a sequence of discrete movements. In general, the term “application” refers to client software that uses the functionality of the example motion control systems described herein. An application is typically an executable, but may also be a DLL, component, or other module that takes advantage of the functionality of the motion control systems described herein.
- The term “module” as used herein refers to a binary block of computer logic that contains functions, objects, components, ActiveX components, .NET source, HTML, XML and/or other computer code that can be executed in real-time or in script form. Several examples of a module include an executable EXE, a dynamic link library DLL, an OLE component or set of components housed within a DLL or EXE, an ActiveX Control, an HTML or XML based Control, a VB script source file, a Java Serverlet, Java Control, Java Object, .NET Package, etc.
- The
motion event manager 130 comprises amotion control component 150 and anevent handling component 152. Themotion event interface 134 further comprises a eventprovider configuration control 154 and amedia view control 156. As used herein, the term “component” refers to a logical organization of computer logic designed to perform a set of operations. Several examples of a component are an OLE Component, an ActiveX Control, an HTML or XML based Control, an HTML or XML based object, a .NET object, a Visual Basic based object, etc. - The
motion control system 120 operates basically as follows. The motion event providers 132 generate what will be referred to as event tokens based on the occurrence of a predetermined event. The event token is associated with the predetermined event in advance and thus identifies the predetermined event. The event token may also contain additional information such as the source of the predetermined event, parameters associated with the predetermined event, and the like. - The event tokens are sent to the
motion event manager 130. The motion event providers 132 andmotion event manager 130 run in separate processes and could perhaps run on separate physical machines connected over a network. As used herein, the term “network” refers to a link between two or more computer systems and may be in the form of a packet based network, a streaming based network, broadcast based network, or peer-to-peer based network. Several network examples include a TCP/IP network, the Internet, an Intranet, a wireless network using WiFi, a wireless network using radio waves and/or other light based signals, etc. - The motion event providers 132 and
motion event manager 130 thus use the system for the inter-process communication provided by the operating system to transmit the event tokens from the event providers 132 to themotion event manager 130. - The
motion event manager 130 notifies themotion control component 150 when the event token is received and the identity of the event token. The action taken by themotion control component 150 upon receipt of an event token depends upon the nature of the event token. The received event token may contain or identify a particular control command, and themotion control component 150 can simply pass that control command to thetarget device 122. The received event token may contain or identify a particular media command, in which case themotion control component 150 may be required to convert the media command into a control command capable of being run by thetarget device 122. Another event token may start, stop, or otherwise control a separate application program run by themotion control component 150. - In the
exemplary system 120, the association of motion media with event tokens is preferably made by themotion event manager 130. This association is typically represented by a table, spreadsheet, or other data storage means capable of defining relationships between event tokens and motion media. Upon receipt of each event token, themotion event manager 130 will identify the motion media previously associated with the received token and send the identified motion media to themotion control component 150 for control of thetarget device 122. - With the foregoing understanding of the basic operation of the
system 120, the details of this exemplarymotion control system 120 will now be described. - The
motion event manager 130 handles the creation of each event provider 132 installed on the system by creating in-proc providers or injecting other providers into their target processes. Theevent manager 130 also catches events fired from each provider 132 and initiates the appropriate motion request for each event. In theexemplary system 120, theevent manager 130 is the only object that communicates directly with themotion control component 150, as will be described in further detail below. Theexemplary event manager 130 is accessible by double clicking its icon in the Windows System Tray in a conventional manner. - The purpose of the
event handling component 152 is to handle the inter-process communications between themotion event manager 130 and the motion event providers 132. The exemplaryevent handling component 152 is or may be a conventional software object referred to as a message pump. - The motion event provider objects 132 are individually designed to monitor user configurable events from a given source. The
exemplary system 120 employs two types of motion event providers 132: simple in-proc servers 132 a,b hosted by themotion event manager 130 andspecialty DLLs 132 c,d that are injected into a target process to monitor event cases. Each motion event provider object 132 also contains anevent configuration control 154 that, as will be described below, allows a user to configure all events supported by the motion event provider objects 132. The motion event provider objects 132 notify themotion event manager 130 of each event caught by the objects 132. - The
motion event manager 130 andmotion control component 150 operate together to allow interaction between the motion event providers 132 and thetarget device 122. - The
motion control component 150 may be or incorporate parts of a software system as disclosed, for example, in U.S. Pat. Nos. 5,691,897 and 5,867,385. The systems disclosed in the '897 and '385 patents are capable of generating device-specific control commands based on hardware independent media commands written to a predetermined application programming interface. - As an alternative, the
motion control component 150 may act as a conduit that passes device-specific control commands and query responses between the motion event providers 132 and thetarget device 122. A motion control component implemented in this manner would not convert between hardware independent media commands and device specific control commands. - A preferred implementation of the
motion control component 152 would be to be for thecomponent 152 to function in both a translation mode and in a pass-through mode. In the translation mode, thecomponent 152 converts media commands into control commands. In the pass-through mode, thecomponent 152 simply passes control commands from the motion event providers 132 to thetarget devices 122. In either mode, query responses are returned from thetarget devices 122 to the event provider 132 in an appropriate format. - The motion
event configuration interface 134 is preferably a visual interface displayed on a screen to allow a user to configure all motion event providers 132 installed on thesystem 120. Theexemplary interface 134 also provides access to themotion web site 136 where new motion media and motion event providers 132 may be downloaded and installed. As will be described in more detail below, the configuration options allowed by theinterface 134 include the ability to enable/disable event providers 132 and map motion media to particular events supported by each provider 132. Theinterface 134 also provides access to themotion web site 136, allowing for new motion media and motion event providers 132 to be downloaded and installed onto the current system. - Each motion event provider 132 contains a
visual configuration control 158 that allows the user to configure the events supported by each provider 132. The exemplary configuration controls 158 use the mediaview control object 156 to gain access to the available motion media in the motion media file 144 that can be mapped to each available event. - These controls may also be configured to allow the user to add new, customized events to the motion event providers 132. The dynamic events can be defined using parameters such as text (usernames, messages, email, etc.), date/time, or any other parameter particular to an event provider's event source.
- The media
view control object 156 provides access to all installed motion media scripts as represented by themotion media file 144. Preferably, the mediaview control object 156 displays a conventional browse/select dialog to allow identification and selection of the available motion media. Thisobject 156 is used by the event provider configuration controls 158 and allows the configuration controls 158 to remain independent of the motion media format. - The media
creation tool application 138 allows the user to customize and/or create motion media. Thisapplication 138 preferably implements a graphical, easier to use, front-end user interface design. - The
motion web site 136 provides a location for the user to download new motion media as well as new and/or updated motion event providers 132. The motion media is preferably stored in a single meta file. New motion media downloaded from themotion web site 136 will be added to this meta file. - The present invention is preferably embodied using the Windows registry; typically, a component category is created for each of the motion event providers 132, allowing the
motion event manager 130 to enumerate all providers 132 installed on the system. Primary event sources 132 are user actions (in any active application supported via a motion event provider) and operating system tasks. - With the foregoing understanding of the modules that form the
exemplary system 120, various scenarios in which these modules typically interact will now be described. - Referring now to
FIG. 2 , depicted therein is the scenario describing the startup process of themotion event manager 130 of thesystem 120. Each of the steps of this startup process will now be described with reference toFIG. 2 . - The
motion event manager 130process 130 begins on system startup. Themotion event manager 130process 130 next queries the MOTION_EVENT_PROVIDER component category in the Windows Registry to enumerate all motion event providers 132 installed on the system. - Third, the registry entry of each of the event providers 132 contains startup information indicating if the particular event provider is either a standard in-proc provider or a specialty provider that is injected into a target process to monitor event conditions.
- Fourth, the
motion event manger 130 creates a new instance of each provider 132. If the event provider 132 is a specialty provider that is injected into a target application process, theevent manger 130 will read the target-process information from the provider's registry entry, find the target process, and perform the DLL-injection. If the target process is not active, themotion event manager 130 will continually monitor the creation of new applications, and perform the injection when/if the requested application is launched. - Fifth, once the event providers 132 are created, the
motion event manager 130 will send the appropriate initialization information to each provider 132, including callback information to allow the event providers 132 to post event messages back to theevent manager 130. - Finally, the event provider 132 reads initialize message data and establish the necessary event syncs to monitor the events. The initialize message data includes a registry key identifying the location of the event configurations and preferences as last set by the motion
event configuration interface 134 or the default installed set. - Referring now to
FIG. 3 , depicted therein is the DLL injection scenario map. This scenario describes the process of injecting a motion event provider DLL into the address space of a target application. - As shown in
FIG. 3 , the first step of this process is for themotion event manager 130 to determine which process into which the motion event provider 132 must be injected based on the registry entry of the provider 132. - Once the target process has been identified, the next step is for the
event manager 130 to install a Windows message hook in the target process. This causes the event provider DLL to be loaded into the target address space of the target process. The event provider DLL has now been loaded into the required process, and will now wait for the “initialize” message from the motion event provider 132. - Referring now to
FIG. 4 , depicted therein is the motion event configuration scenario map. This scenario map describes the process of configuring motion events of each of the motion event providers 132. - First, the user launches the motion
event configuration interface 134 from system tray interface of themotion event manager 130. - Each event provider object 132 supports a custom
visual control 154 that can be used to edit the object's supported events. Theevent configuration interface 134 creates and hosts thesevisual controls 154 for the user. - Next, when the event
provider configuration control 154 is created and initialized, it will receive the location in theWindows Registry 142 of its persisted event data, which will be loaded into thecontrol 154. - Next, the user will select an event provider 132 to configure. Individual events may be mapped to motion actions, and particular events (as well as the entire event provider itself) may be deactivated if desired. As noted above, these event configuration controls 154 may also provide the means to add additional, customized events based on input user parameters (custom text strings, buddy chat names, email messages, etc).
- When the user selects an event to configure, the event
provider configuration control 154 will defer to the mediaview control object 156. The mediaview control object 156 displays all available motion media via a dialog box, allowing the user to make a selection. - Finally, once the user makes a motion media selection, the media
view control object 156 returns data back to the event provider configuration control object 154 (including human-readable description text of the event for display as well as a data token which can later be used to identify media selection). Theconfiguration control object 154 then persists this information to theWindows Registry 142. - Referring now to
FIG. 5 , depicted therein is a motion event scenario map. This scenario describes the process of handling a motion event. - The scenario depicted in
FIG. 5 begins whenever an event occurs. The occurrence of an event may be caused from a user action, operating system event, or an event situation monitored in a third-party application. - The event provider 132 then fires a event token associated with this event to the
event manager 130. The event token has previously been stored in the registry during the event configuration process. If the provider 132 requires queried data to be returned, the provider 132 will also pass the necessary callback data to theevent manager 130. - The
event manager 130 next receives the event and passes the requested media information to themotion control component 150. Themotion control component 150 then executes the specified motion media on thetarget motion device 122. - Finally, if a query action was requested, the
motion control component 150 will return the appropriate data. Themotion event manger 130 will send the data through the specified event provider callback mechanism. - Depicted in
FIG. 6 is a motion web site scenario map. The scenario ofFIG. 6 describes how a user may obtain new motion media and motion event providers 132 from themotion web site 136. - This process may be started when users visit the
motion web site 136 to browse currently available motion event providers 132 and new motion media. InFIG. 6 , thereference character 144 a is used to represent a motion media file stored locally by thesystem 120, while thereference character 144 represents a motion media file stored at a remote location. - Next, the user selects the desired provider/media download option, and the new software is installed into the
motion event manager 130 including themotion control component 150. - The next time the motion
event configuration interface 134 is launched, the user will be able to configure the new event provider 132 or motion media in the local motion media file 144 a. - Alternatively, users may download new event providers 132 and motion media directly from within the motion event Configuration dialog interface. This configuration dialog will provide the following options to the user: Download new Motion Media and/or Download/install new motion event providers 132. The user or the
motion event manager 130 may also check for new versions of currently installed motion media and/or event providers 132. - Next, the user selects the desired provide/media download or update option, and the configuration
dialog interface object 134 automatically downloads and installs the new software from themedia web site 136. - Finally, once the new software is installed the
configuration dialog 134 will automatically update to provide access to the new components and/or media. - Referring now to
FIG. 7 , depicted therein is the system shutdown scenario map. This scenario describes the process of shutting down the exemplaryevent manager module 130 associated with themotion control component 150. - Upon operating system shutdown, the
motion event manager 130 will prepare to terminate. - The
event manager 130 next posts a shutdown message to each event provider 132 currently being managed by themanager 130. Specialty event providers 132 that have been injected into external processes may have already finished if the target process has been shutdown. In this case those event providers 132 would have already notified theevent manager 130 that they are no longer available. - Each event provider 132 performs any required shutdown tasks.
- Upon finishing any shutdown tasks, each provider 132 will notify the event manager 132 that the provider 132 is now finished.
- Once the
event manager 130 receives notifications that each of the event providers 132 managed thereby have been shutdown, theevent manager 130 itself is now finished. - Referring now to
FIG. 8 , depicted therein is a scenario map illustrating the mapping of text to motion events. This scenario generally describes the mapping of text based event situations to motion. - The first step of this process is for a text based event situation to occur. This text could be one or more of the following: (a) a particular sub-string in an Instant Message or the entire message string itself; (b) an Instant Message sent from a target screen or ‘buddy’ name; (c) a text string converted from a speech-to-text engine installed on the user's machine; and/or (d) an email message meeting previously configured criteria (Sent From, Subject, message content, etc). In the case of an event created using a peer-to-peer networked application such as Instant Messenger-type process, text is entered at a remote source application and sent as a text message to a receiving application.
- The motion event provider 132 monitoring the specific text based event catches the event, and performs any pre-processing of the text required to identify the particular event. In the peer-to-peer application described above, a DLL functioning as the event provider 132 is injected into the receiving application; the DLL event provider 132 intercepts the message received by the receiving application and treats the received message as an event.
- Once an event has been identified, the event provider 132 will lookup the corresponding motion event token as previously configured. As generally described above, the motion event tokens are pre-loaded upon initialization. In the peer-to-peer example described above, the DLL functioning as the event provider 132 sends the text message as part of the event token to the
event manager 130 using a process-to-process communication system as generally described above. - After the event token containing the text message is sent to the
motion event manager 130, theevent manager 130 determines the type of event represented by the received token. - If the
event manager 130 determines that the received event token corresponds to a text event, theevent manager 130 next parses the text parameter from the event token. Themotion event manager 130 looks up the motion media associated with the event type and event text parameter. The appropriate motion media is then sent to themotion control component 150 for execution on thetarget motion device 122 as described above with reference toFIG. 5 . - The process described above with reference to
FIG. 8 can also occur in the reverse. In particular, theevent manager 130 uses themotion control component 150 to continually query thetarget device 122 for state information. When the state information meets certain parameters, thecontrol component 150 causes the event manager to ‘create’ a new event (such as a text event) and send it to an event provider 132. - The event provider 132 in turn then causes the receiving application to sent a message to a remote peer-to-peer application; again, the receiving and remote peer-to-peer applications may be Instant Messenger compatible applications.
- An example of the use of the present system to verify motion status would be for the
event manager 130 to continually or periodically query thetarget device 122 through themotion control component 150 for status parameters that indicate a fault condition. Once a fault condition occurs, theevent manager 130 builds a text message that describes the fault and then sends the text message to a remote application, such as an Instant Messenger user, using process-to-process communication system and the peer-to-peer networked application. - The following Table A describes the interface specifications for components of the exemplary
motion control system 120 described above using the exemplarymotion control component 150. -
TABLE A component interface method(s)/description motion event IXMCEventProviderMgt EnumerateProviders used by manager 30 configuration dialog object to get a list of all installed motion event providers 132 EnableProvider( ) used to enable/disable given event providers. will be called from the configuration dialog object IXMCEventScheme GetSchemes( ) used by configuration dialog object to get current list of schemes on the system AddScheme( ) - used by configuration dialog object to add a new scheme RemoveScheme( ) - used by configuration dialog object to remove a given scheme RenameScheme( ) - used by configuration dialog object to rename a given scheme Event IXMCEventConfig Initialize( ) - called by the configuration configuration dialog object controls 158 which hosts this control, used to pass required init data, such as 1) current registry location where event configuration data may be loaded/persisted, 2) interface to the media view control 156, etc.. Media View IXMCMediaViewCtrl method: SelectMedia( ) - called Control 156by each event configuration control. This method will display a dialog to visualize all motion media available on the system and return a tokenized data param that can later identify the media item selected - In the following discussion, the details of a number of the exemplary components of the
system 120 will now be described. - The
Windows Registry 142 is used to persist event management with motion control configuration data. - Data associated with the motion event providers 132 is persisted to the
Windows Registry 142 primarily to accommodate event provider DLLs that need to be injected into a target process, an environment where those DLLs may not be able to rely on standard COM storage alternatives. - At runtime, when the
motion event manager 130 initializes an event provider, the provider will receive a location in the registry where it should read its previously configured event data. - At design time, when hosted within the motion
event configuration interface 134, the event configuration controls 156 of the event providers 132 receive the registry location, and will persist configuration changes to that location. - Event providers will persist both standard (hard coded) and custom events to their registry storage location. Associated with each event will be the configured motion event token data, which the provider will use when firing event notifications back to the
motion event manager 130. - The
motion event manager 130 manages all registry locations for the event provider objects. - The event manager provides a mechanism to support different event schemes. This allows configurations unique for several different users, situations, or motion devices. When a new scheme is selected via the motion
event configuration interface 134, theevent manager 130 will pass the new scheme registry location to each event provider object 132, allowing access to the new scheme data. Each scheme will be located in a unique sub key under the primary event manager registry location. - The
user interface components system 120 may be implemented in many different forms. The motionevent configuration control 154 is used to configure all motion event providers 132 installed on the system, as well as to provide access to themotion web site 136 where new motion media and motion providers may be downloaded and installed. The interface of themedia creation tool 138 is a preferably graphical representation of the motion device or system, where simple drag-drop, click, and record operations will facilitate the creating and modification of motion media. - The
system 120 is designed to be easily extendible via new motion event provider and motion media components. Thesystem 120 is also capable of supporting any number of additional event sources with the addition of new motion event providers 132 by registering these new providers with thesystem 120. These event providers 132 can link to virtually any event source to atarget system 122. - The motion media formats can be modified and extended without requiring changes to any event provider objects. For example, a XMCMediaCtrl object proxies the raw motion media format to the event providers. Accordingly, once the XMCMediaCtrl component is updated to handle any new media formats, the event providers 132 may, by design, make use of the changes.
- Instead of triggering entire motion programs as described above with reference to
FIG. 6 , a motion program or media set may be streamed to thedevice 122 through thesystem 120. Whether or not and how the media plays may be controlled by captured events. For example, a media player may fire events based on different musical notes or tones. When such events are received, one media stream may be selected over another, thus causing themotion device 122 to perform different actions. This may also occur with the standard motion programs described above. - Very large motion programs may be downloaded in partial form and then either downloaded in full over time or as certain specified events occur in the system.
- Similar to streaming media support, single motion operations may also be supported in which a specified event causes a single motion operation to take place immediately. One example of this would be an event that causes movement of one axis in the clockwise direction.
- Referring now to
FIG. 9 , depicted therein is a second example of amotion control system 220 constructed in accordance with, and embodying, the principles of the present invention. Themotion control system 220 comprises amachine platform 222 and anevent notification system 224. - The
machine platform 222 may be implemented using a controller neutral platform technology as described, for example, in U.S. Pat. Nos. 5,691,897, 5,867,385, 6,209,037, 6,480,896, 6,513,058, 6,516,236, 6,542,925 and/or 6,571,141, which are incorporated herein by reference. However, themachine platform 222 is or may be any motion control system, whether controller dependent or controller neutral, that comprises a machine converts motion commands into movement of an object. - In the context of the present application, the term “controller” refers to the hardware or software that contains the logic used to run the machine. Typically the controller one or more of a PLC, CNC Controller, or Motion Controller. The controller contains the main control loop used to position, monitor, or otherwise direct a machine to carry out useful automated tasks.
- The term “machine” is used herein to refer to a physical machine or device asset used to perform a specified task. For example, a machine may be a CNC Mill used to shape metal, a pick-n-place machine used to position parts on a circuit board, a robotic machine used to perform surgery, a medical data input device used to collect the vitals from a human being (i.e. blood glucose meter, asthma meter, etc), a gaming device used when playing a game, a robotic toy, an animatronics figure, a robotic machine used to deliver goods to a warehouse or to people, an automobile, truck or farm vehicle, a boat or ship that maneuvers in water, a airplane, jet, helicopter and/or spacecraft. Any self powered machine or device (mobile or not) that is either directly controlled by humans or automatically controlled via a computer based system falls within the definition of “machine” as used herein. The term “device” as used herein is essentially synonymous with the term “machine,” but may be used in reference to a machine with a relatively small footprint.
- The example
event notification system 224 comprises amain event handler 230, one or moreevent handler applications 232, and one or more event handler property pages 234. The examplemain event handler 230 comprises adata queue 236. - The
main event handler 230 is a component that is in communication with themachine platform 222 such that themain event handler 230 receives one or more events from themachine platform 222. Theexample data queue 236 within themain event handler 230 is a standard data queue that employs first-in/last-out technology. Optionally, thedata queue 236 may be implemented as a priority queue that allows the items in the queue to be organized based on given priorities associated with the data contents of each item in the queue. Thedata queue 236 may optionally use a timing scheme that ensures that all items within the queue are processed within a given time frame, such that no items within the queue are ‘starved-out’ when a high frequency of higher priority items are received. - The
event handler application 232 is used to configure and run themain event handler 230. The exampleevent handler application 232 is a Windows System Tray application. Theevent handler application 232 is optional, and themain event handler 230 may be run and configured using other systems and methods. The eventhandler property page 234 is used to configure the settings of themain event handler 230 by presenting a user interface that allows the user to see the settings of themain event handler 230 and/or to change these settings. - The
main event handler 230 is also in communication with one or more possible event destinations such as anupstream event handler 240 and/or adownstream event handler 242. - The example
upstream event handler 240 is a module similar to themain event handler 230 that serves data to themain event handler 230. The exampledownstream event handler 242 is also a module similar to themain event handler 230, but one that receives data from themain event handler 230. From the perspective of theupstream event handler 240, themain event handler 230 is a downstream event client. From the perspective of thedownstream event handler 242, themain event handler 230 is an upstream event client. - The
main event handler 230 may also be in communication with one or more event destinations through an intermediate destination such as a sharedmemory system 250, amemory queue 252, and/or anetwork protocol 254. The sharedmemory system 250 is a block of memory that is accessible to different modules and/or applications. Theexample memory queue 252 uses Microsoft Message Queue (MSMQ) technology or a similar technology. MSMQ allows for communication with other modules and/or applications using a delayed messaging technology called Message Queuing. Theexample network protocol 254 is formed using TCP/IP or UDP broadcast protocols as a mechanism of sending output data to another target. The TCP/IP protocol specifies specific data target(s), and the UDP protocol broadcasts data to all nodes on a given network. - The
main event handler 230 delegates one or more events received from themachine platform 222 to one or more event destinations such as theupstream event handler 240 and/or thedownstream event handler 242. In addition or instead, themain event handler 230 may delegate one or more events received from themachine platform 222 to additional event destinations using one or more of the intermediate destinations such as the sharedmemory system 250, thememory queue 252, and/or thenetwork protocol 254. - The
main event handler 230 may further be in communication with an alternate event source such as adata transport system 260. The data transport system may be implemented using the data router technology described in co-pending U.S. patent application Ser. No. 10/844,025, which is incorporated herein by reference. Thedata transport system 260 routes data outputs to various output sources, one of which may be themain event handler 230. - If the
motion control system 220 employs thedata transport system 260, themain event handler 230 may also be configured to delegate events from thedata transport system 260 to the event destinations such as theupstream client 240 and/or thedownstream event handler 242 and/or to intermediate destinations such as the sharedmemory system 250, thememory queue 252, and/or thenetwork protocol 254. - The
event notification system 224 may use an event handler, such as themain event handler 230, which is internally configured to handle communications with the event destinations and/or intermediate destinations as shown inFIG. 9 . Alternatively, themotion control system 320 may use anevent notification system 224 a having a modularmain event handler 230 a as depicted inFIG. 10 . Themodular event handler 230 a is a more modular design where each output is modularized, thus giving theevent handler 230 a the capability to select from a list of destination modules either programmatically or through a user interface. - In particular, the example modular
main event handler 230 a further comprises at least one event communication component 270 configured to handle the details of communicating with one or more of the event destinations and intermediate destinations.FIG. 10 shows that the modularmain event handler 230 a is in communication with the following event communication components: acomponent 270 a configured to communicate using e-mail or SMTP protocols; acomponent 270 b configured to access shared memory such as the sharedmemory system 250; acomponent 270 c configured to communicate with a network protocol such as thenetwork protocol 254; acomponent 270 d configured to communicate with a memory queue such as thememory queue 252; acomponent 270 e configured to communicate with a peer-to-peer communication system such as Instant Messenger; acomponent 270 f configured to communicate using XML messaging; acomponent 270 g configured to communicate using envelope based communication services such as SOAP; and/orother communications components 270 h. - More than one event communication component 270 of the same type may be used simultaneously. For example, the
event handler 230 a may use two event client components configured to communicate with a network protocol where each component is capable of sending data to a different destination network address. -
FIG. 11 depicts the steps that take place when configuring thesystem 220 using an application such as the event handler application 301 described above. Initially, in a first step theevent handler application 232 queries theevent handler 230 for its event handler property page or pages 234. Once received, the event handler property page orpages 234 are displayed to the user. In a second step, configuration changes are saved to themain event handler 230 by changing the properties and/or calling methods of theevent handler 230. -
FIG. 12 depicts the steps that occur when configuring theevent handler 230 from another component. In a first step, the other component, such as thedata transport 260, queries theevent handler 230 for its event handler property page(s) 234, which, once received, are displayed to the user. For example, this may occur via a property page of the calling component. In a second step, configuration changes are saved to theevent handler 230 by changing the properties of theevent handler 230 and/or calling methods on theevent handler 230. When configuring theevent handler 230, each output may be enabled or disabled. Later, when processing data, data is only sent to each enabled output. - Once configured, the
event handler 230 must be initialized to prepare it for use.FIG. 13 depicts the steps that take place when initializing theevent handler 230. First, a component, such as thedata transport 260 and/or theevent handler application 232, directs theevent handler 230 to initialize itself. Next, theevent handler 230 uses its internal properties, which were previously configured during the configuration stage, to connect to amachine platform 222 or anupstream event client 240, and subscribe to the data items specified in the configuration data. - In practice, the data items specified in the configuration data must be data that are published by the
machine platform 222, or failures may occur. As used herein, the term “publish” (or publish/subscribe) refers to a method of receiving data updates where the client subscribes to data published by the server. For example, a server may have three data items available for subscriptions: A, B, C. The client may then subscribe to any of these data items upon which the client may receive data updates based upon certain criteria such as the data value of the subscribed data item changing, a time period passing, or some other event occurring in the system such as a trigger variable firing, etc. The term “trigger variable” refers to variable or data item that causes the registered actions to be carried out when the variable or data item's event conditions are met. - Once configured and initialized the
event handler 230 is ready to receive events for each of the subscribed data items.FIG. 14 depicts the steps that take place when processing events. First, the event is received from an upstream component such as themachine platform 222 and/or anupstream event handler 240 that is daisy chained to themain event handler 230. - Upon receiving the event, the data is optionally placed at the back of the
internal data queue 236. If a queue is not used, the data is immediately sent to all event destinations, such as sharedmemory system 250 or thenetwork protocol 254, that are in an enabled state for that event. If theinternal data queue 236 is used, data items are pulled off the data queue according to the rules for that queue and sent to all outputs that are in an enabled state for that event. As described above, thedata queue 236 may be a first-in/last-out queue, a priority queue, and/or a queue implementing a timing scheme. - In addition to processing events, the
event handler 230 may also process commands via API calls to one of its interfaces. For example, thedata transport 260 may direct theevent handler 230 to send data to an event destination by calling an API of theevent handler 230.FIG. 15 depicts the steps that occur when processing a command using API calls. First, the remote component such as thedata transport 260 may call an event handler API through which the data is passed. When called, the API may optionally place the data into aninternal data queue 236. If a data queue is not used, the data is passed directly to all outputs, such as the sharedmemory system 250 or thenetwork protocol 254, that are in an enabled state for a given event. - Optionally, the
main event handler 230 may be daisy chained with one or moreupstream event handlers 240 and/or one or moredownstream event handlers 242. In this case, data is received fromupstream event handlers 240 and/or sent todownstream event handlers 242.FIG. 16 depicts the steps that occur when processing events or commands in a daisy chained configuration. - First, if an event handler is connected upstream to the
main event handler 230, the data is received from thatupstream event handler 240 as an event and/or as an API call. If anupstream event handler 240 is not used, data may be received in the normal manner either via an event or API call. Next, upon receiving the data as an event and/or as an API call, the data may be placed at the back of aninternal data queue 236 if used. If a data queue is not used, the data is sent directly to all outputs (such as sharedmemory system 250 or network protocol 254) that are in an enabled state. - Third, when using the
internal data queue 236, the data is pulled from the data queue and sent to all enabled outputs. Again, the data queue may be a first-in/last-out queue, a priority queue, and/or a queue implementing a timing scheme. - Fourth, if a shared memory 306 output is used and is enabled, the data is sent to a shared memory block.
- Fifth, if a
network protocol 254 is used and is enabled, the data is sent to zero, one, or more event destinations previously configured for this output in the case of a TCP/IP network. As described above, the data may be sent as a UDP broadcast to all nodes on a network or group of networks. TCP/IP may also be used to send the data via a tunneling mechanism, such as is used within a Virtual Private Network (like those implemented with Microsoft RRAS), from thecurrent event handler 230 to another event handler 230 (or even to a group of event handlers 230), where the receiving component receives the TCP/IP or UDP data and then translates it into an event or API input. - Sixth, if a
message queue 252, such as a MSMQ, event destination is used and enabled, the data is sent via themessage queue 252 to another application or component, or even to another event handler 230 (or group of components). - Seventh, if one or more
upstream event handlers 240 and/or one or moredownstream event handlers 242 are used and enabled, themain event handler 230 sends data directly to any such event handlers 24- and/or 242. - As an optional eighth step, a
downstream event handler 242 may be configured to communicate with theupstream event handler 230 via the shared memory 306 and/or other standard synchronization events such as the event object supported within Win32. - When daisy chaining event handlers, it may also be important to pass configuration data (and other data) between the event handler components. When configuring any such event handler components as depicted in
FIG. 15 , thedownstream event handler 242 may pass configuration information on to themain event handler 230. For example, when subscribing to data, any downstream event handler will notify any upstream event handler of all data items that are to be subscribed. The subscribing data may be continually passed along the daisy chain to modify any upstream event handlers and/or directly notify themachine platform 222, if it is connected directly to themachine platform 222. - The
event handler 230 is preferably a modular system made up of a set of components (i.e. each component is based on a component technology such as OLE/COM from Microsoft Corporation). Optionally, each component may use a separate ‘parallel’ ActiveX component and/or a property page component to implement all user interface aspects of the main component. Each ActiveX and/or property page component may be implemented either within the main component module or separately in its own module. Bundling each object within one module is not required as they may be located at any location (i.e. across a network, and so forth), but doing so may optimize all communication between modules. How and where components are implemented is a logistical decision. Once components are built and deployed to the field, it is difficult to update a single component if all components are implemented within a single DLL or EXE module. -
FIG. 18 depicts an example of the interfaces exposed by the example event handler components. In the examplemotion control system 220, all components making up thesystem 220 at a minimum implement a single interface—the IXMCDirect interface. Optionally, if they are to receive events from other components, theevent handler components event handler components machine platform 222. The IXMCDirect, IXMCDirectSink, and IXMCaCNCEventDataSink interfaces will be described in further detail below. - OLE Categories are used to determine how many components fall into a certain group of components. Currently, components used to form the event handler components use what will be referred to herein as the XMC Data Router components. The XMC Data Router components are general data router components support the general read, write, and configure API.
- The IXMCDirect interface is used for most communications between all components making up the
event handler 230. The following methods make up this interface (as specified in the standard OLE/COM IDL format). - The IXMCDirect interface is made up of the following functions.
-
- GetProperty—This method is used to query a specific property from the component implementing the interface.
- SetProperty—This method is used to set a specific property from the component implementing the interface.
- InvokeMethod—This method is used to invoke a specific action on the component implementing the interface. It should be noted that an action can cause an event to occur, carry out a certain operation, query a value and/or set a value within the component implementing the method.
- A more detailed description of each method implemented by the object is described below.
-
- IXMCDirect::GetProperty
- Syntax HRESULT GetProperty(LPCTSTR pszPropName, LPXMC_PARAM_DATA rgData, DWORD dwCount);
- Parameters LPCTSTR pszPropName—string name of the property to query.
- LPXMC_PARAM_DATA rgData—array of XMC_PARAM_DATA types that specify each parameter corresponding to the property. For example, a certain property may be made up of a number of elements—in this case an array of XMC_PARAM_DATA items is returned, one for each element making up the property. In most cases, a property is made up of a single element, thus a single element array is passed to this method. For more information on the XMC_PARAM_DATA type, see below.
- DWORD dwCount—number of XMC_PARAM_DATA elements in the rgData array.
Return HRESULT—NOERROR on success, or error code on Value failure.
- The IXMCDirect::GetProperty method is used to query the property corresponding to the property name ‘pszPropName’. Each component defines the properties that it supports.
-
- IXMCDirect::SetProperty
- Syntax HRESULT SetProperty(LPCTSTR pszPropName, LPXMC_PARAM_DATA rgData, DWORD dwCount);
- Parameters LPCTSTR pszPropName—string name of the property to set.
- LPXMC_PARAM_DATA rgData—array of XMC_PARAM_DATA types that specify each parameter corresponding to the property. For example, a certain property may be made up of a number of elements—in this case an array of XMC_PARAM_DATA items is returned, one for each element making up the property. In most cases, a property is made up of a single element, thus a single element array is passed to this method. For more information on the XMC_PARAM_DATA type, see below.
- DWORD dwCount—number of XMC_PARAM_DATA elements in the rgData array.
- Return HRESULT—NOERROR on success, or error code on Value failure.
- This IXMCDirect::SetProperty method is used to set a property in the component corresponding to the ‘pszPropName’ property. For the set of properties supported by the component, see the specific component description.
-
- IXMCDirect::InvokeMethod
- Syntax HRESULT InvokeMethod(DWORD dwMethodIdx, LPXMC_PARAM_DATA rgData, DWORD dwCount);
- Parameters DWORD dwMethodIdx—number corresponding to the specific method to invoke. For more information on the method indexes available, see the set of namespaces defined for the component.
- LPXMC_PARAM_DATA rgData [optional] —array of XMC_PARAM_DATA types that specify each parameter for the method called. For more information on the XMC_PARAM_DATA type, see below.
- NOTE: if no parameters exist for the method called, a value of NULL must be passed in.
- DWORD dwCount [optional]—number of XMC_PARAM_DATA elements in the rgData array.
- NOTE: if no parameters exist for the method called, a value of 0 (zero) must be passed in for this parameter.
- LPXMC_PARAM_DATA rgData [optional]—namespace associated with the instance of the custom extension module added.
- Return HRESULT—NOERROR on success, or error code on Value failure.
- The IXMCDirect::InvokeMethod method is used to call a specific method implemented by the component. For more information on the methods supported, see the description of the specific component.
- The IXMCDirectSink interface is an event reception point on which one component can send event data to another. The component implementing this interface is the event receiver, and the event source calls the interface passing to it event data.
- The IXMCDirectSink interface is made up of the following functions:
-
- OnEvent—This method is called by the event source when an event occurs (i.e. the conditions defining the event are met).
- OnError—This method is called by the event source when an error occurs.
- A more detailed description of each method implemented by the object is described below.
-
- IXMCDirectSink::OnEvent
- Syntax HRESULT OnEvent(long IApiIdx, SAFEARRAY** ppSA);
- Parameters long IApiIdx—index associated with the event type . . .
- SAFEARRAY** ppSA—pointer to a pointer to a SAFEARRAY containing an array of XMC_PARAM_DATA structures. For more information on the XMC_PARAM_DATA type, see below.
- Return HRESULT—NOERROR on success, or error code on Value failure.
- Notes The SAFEARRAY passed to this method contains an array of XMC_PARAM_DATA structures. This array has the following entries:
- rgData[0] LONG IConnectionCookie—unique cookie associated with this connection to the XMC Motion Server (returned when calling the InitializeHardware method on the XMC Motion Server).
- rgData[1] DWORD dwSubscriptionCookie—unique cookie associated with the subscription for which this event has fired. This cookie is returned when making the subscription.
- rgData[2] DWORD dwDataCookie—unique cookie associated with the specific data change that triggered the event. This cookie is generated within the XMC Motion Server.
- rgData[3] LPCTSTR pszItemName—name of the item or variable for which the subscription is associated.
- rgData[4] double dfTimeStamp—number of milliseconds passed from the time that the event pump, implemented by the XMC Motion Server, was first started.
- rgData[5] DWORD dwDataCount—number of data values associated with the event (i.e. the number of structure elements that follow).
- rgData[6 Number or String—actual data values associated with the +n] event.
- The IXMCDirectSink::OnEvent method is called by the event source and passed the event data in a SAFEARRAY form for easy marshalling across process boundaries.
-
- IXMCDirectSink::OnError
- Syntax HRESULT OnError(long IApiIdx, SAFEARRAY** ppSA); Parameters long IApiIdx—index associated with the event type . . .
- SAFEARRAY** ppSA—pointer to a pointer to a SAFEARRAY containing an array of XMC_PARAM_DATA structures. For more information on the XMC_PARAM_DATA type, see below.
- Return HRESULT—NOERROR on success, or error code on Value failure.
- Notes The SAFEARRAY passed to this method contains an array of XMC_PARAM_DATA structures. This array has the following entries:
- rgData[0] LONG IConnectionCookie—unique cookie associated with this connection to the XMC Motion Server (returned when calling the InitializeHardware method on the XMC Motion Server).
- rgData[1] DWORD dwSubscriptionCookie—unique cookie associated with the subscription for which this event has fired. This cookie is returned when making the subscription.
- rgData[2] DWORD dwDataCookie—unique cookie associated with the specific data change that triggered the event. This cookie is generated within the XMC Motion Server.
- rgData[3] LPCTSTR pszItemName—name of the item or variable for which the subscription is associated.
- rgData[4] double dfTimeStamp—number of milliseconds passed from the time that the event pump, implemented by the XMC Motion Server, was first started.
- rgData[5] HRESULT hrResult—result code of the error for which the event is associated.
- rgData[6] LPCTSTR pszError—string description of the error.
- rgData[7] LONG ISrcError—error code describing the source of the error. For example, this may be an error code returned by a computer controlled piece of hardware.
- rgData[8] LPCTSTR pszSrcError—string describing the source error.
- The IXMCDirectSink::OnError method is called by the event source when an error occurs and passed the event error data in a SAFEARRAY form for easy marshalling across process boundaries.
- In order to receive events directly from the
machine platform 222, theevent handler 230 also supports the IXMCaCNCEventDataSink interface as specified in themachine platform 222 product sold by ROY-G-BIV Corporation. -
[ object, uuid(15D1A3C6-9948-47c7-AFC1-3932AF4518D7), dual, helpstring(“IXMCaCNCEventDataSink Interface”), pointer_default(unique), oleautomation ] interface IXMCaCNCEventDataSink : IDispatch { [id(1), helpstring(“method OnData”)] HRESULT OnData( [in] long IConnectionCookie, [in] long ISubscriptionCookie, [in] long IDataCookie, [in] BSTR bstrName, [in,out] SAFEARRAY(VARIANT)* pvData, [in] double dfTimeStamp ); [id(2), helpstring(“method OnError”)] HRESULT OnError( [in] long IConnectionCookie, [in] long ISubscriptionCookie, [in] long IDataCookie, [in] BSTR bstrName, [in] long hrErr, [in] BSTR bstrErr, [in] long ISrcErr, [in] BSTR bstrSrcErr ); }; - Referring now to
FIG. 19 of the drawing, depicted there in is an example of the IXMCaCNCEventDataSink OLE Interface. - The following methods make up the IXMCaCNCEventDataSink interface.
-
Event Name Description OnData This event is called on the client application each time the event conditions are met for a given enabled subscription. OnError This event is called on the client application each time an error occurs while processing a subscription. -
- OnData Event
- Syntax //C++
- HRESULT OnData([in] long IConnectionCookie,
- [in] long ISubscriptionCookie,
- [in] long IDataCookie,
- [in] BSTR bstrName,
- [in,out] SAFEARRAY(VARIANT)* pvData,
- [in] double dfTimeStamp)
- ‘OLE Automation
- Event OnData(IConnectionCookie As Long,
- ISubscriptionCookie As Long,
- IDataCookie As Long,
- bstrName As String,
- pvData( )As Variant,
- dfTimeStamp As Double)
- HRESULT OnData([in] long IConnectionCookie,
- Parameters IConnectionCookie As Long—this is the connection cookie returned by the call to InitializeHardware. Each connection cookie is unique to each application.
- ISubscriptionCookie As Long—this is the subscription cookie returned by the call to SubscribeVariable.
- IDataCookie As Long—this is the data cookie that is unique to each operation made by the internal data processing performed by XMC. For example each unsolicited read made by XMC is associated a unique data cookie.
- bstrName As String—this is the name of the subscribed variable for which the event data is associated.
- pvData( )As Variant—this is the actual data for the event and is in the following form:
- pvData(0)=number of elements.
- pvData(1+n)=data values.
- dfTimeStamp As Double—this is the timestamp of the data specified in milliseconds from the start of the XMC Motion Server.
- The OnData event is called each time the event condition for an enabled subscription is met for a subscription configured by a client application. Deadlock can occur when running in multi-application mode and calls to other XMC API are made from within this event hander or another event raised by this event handler. To avoid this situation, applications that implement this method should copy all data from this method into a temporary buffer and immediately return without calling other XMC API.
-
- OnError Event
- Syntax //C++
- HRESULT OnError([in] long IConnectionCookie,
- [in] long ISubscriptionCookie,
- [in] long IDataCookie,
- [in] BSTR bstrName,
- [in] HRESULT hrErr,
- [in] BSTR bstErr,
- [in] long ISrcErr,
- [in] BSTR bstrSrcErr,
- [in] double dfTimeStamp)
- ‘OLE Automation
- Event OnError(IConnectionCookie As Long,
- ISubscriptionCookie As Long,
- IDataCookie As Long,
- bstrName As String,
- hrErr As Long,
- bstrErr As String,
- ISrcErr As Long,
- bstrSrcErr As String,
- dfTimeStamp As Double)
- HRESULT OnError([in] long IConnectionCookie,
- Parameters IConnectionCookie As Long—this is the connection cookie returned by the call to InitializeHardware. Each connection cookie is unique to each application.
- ISubscriptionCookie As Long—this is the subscription cookie returned by the call to SubscribeVariable.
- IDataCookie As Long—this is the data cookie that is unique to each operation made by the internal data processing performed by XMC. For example each unsolicited read made by XMC is associated a unique data cookie.
- bstrName As String—this is the name of the subscribed variable for which the event data is associated.
- hrErr As Long—this is the operating system error received.
- bstrErr As String—this is a string describing the operating system error received.
- ISrcErr As Long—this is the source error received that describes the error information in the context of the target control system. This error value is only provided when available.
- bstrSrcErr As String—this is a string description of the source error received (when available).
- dfTimeStamp As Double—this is the timestamp of the data specified in milliseconds from the start of the XMC Motion Server.
- The OnError event is called each time an error occurs for a subscription configured by a client application. Applications that implement this method should immediately copy the data received in a temporary buffer and or array and immediately return so as to not cause deadlock within their application. Deadlock can occur when running in multi-application mode and calls to other XMC API are made from within this event handler or another event raised by this event handler.
- The Methods and properties exposed by the XMC Event Client component will now be described in further detail.
- This section describes the general component properties of each property supported by the
event handler 230 component. -
TARGETMACHINE rgData[0] - (string); name of the target machine for which the XMC Event Client component is to connect up to and receive data from. OPTIONS rgData[0] - (DWORD); options describing how the XMC Event Client is to operate. The following options are supported. OF_AUTOLOAD_ENABLED - when specified, the component automatically loads the configuration settings specified in the configuration file specified in the CONFIGFILE property. OF_AUTOSTART_ENABLED - when specified, the component automatically connects and starts monitoring data items that are specified. OF_MAPVARIABLES_ENABLED - when specified, the variables listed in the variable mapping file specified in VARMAPFILE property are loaded. OF_QUEUE_EVENT_ENABLED - when specified, all data received through an event are placed at the back of the data queue. OF_QUEUE_API_CALLS_ENABLED - when specified, all data received on the Write API are placed at the back of the data queue. OF_WAIT_FOR_DATA_RECEIVED - when specified, the component waits until an external application signals the data ready event before placing more data in the output(s). OF_DELETE_OLD_QUEUE_ITEMS - when specified, data items within the data queue that have been in the data queue for a time period longer than the amount specified in the DATAOLDTIMEOUT property are purged from the data queue. OF_COLLECT_DATA_ALWAYS - when specified, data items are subscribed in such a way that updates are always sent, even when the data items does not change. QUEUEMAXSIZE rgData[0] - (DWORD); specifies the maximum number of items allowed in the data queue. Items received after this maximum value is reached are ignored. DATARECEIVEDTIMEOUT rgData[0] - (DWORD); specifies the amount of time to wait for an application to signal the data ready event. If this value is surpassed, the data in the front of the data queue is sent to the outputs. DATAOLDTIMEOUT rgData[0] - (DWORD); specifies how long data items are allowed to remain in the data queue before being purged. CONFIGFILE rgData[0] - (string); specifies the name of the file from which all auto-load configuration settings are read. VARMAPFILE rgData[0] - (string); specifies the name of the file from which all variable mappings are loaded. VAR_MONITOR_COUNT rgData[0] - (DWORD); specifies the total number of variables to monitor. VAR_MONITOR— rgData[0] - (string); specifies the name of the ‘n'th variable to monitor. VAR_READ_COUNT rgData[0] - (DWORD); specifies the total number of variables to read. VAR_READ— rgData[0] - (string); specifies the name of the ‘n'th variable to read. rgData[1] - (string); specifies the name of the ‘m'th variable to monitor for which this variable is associated. - This section describes the general component methods supported by the majority of the components. For the specific list of methods supported by any given component, see the section describing that given component.
-
- XMC_DE_BROWSE_GET_COUNT
-
Index 8020 Data In None Data Out rgData[0] - (number) DWORD, number of browse elements. - The XMC_DE_BROWSE_GET_COUNT method returns the number of data items in the browse set supported by the component.
-
- XMC_DE_BROWSE_GET_ITEMS
-
Index 8021 Data In rgData[0] - (number) DWORD, maximum number of elements to collect. Data Out rgData[0] - (number) number of elements collected, total number of elements will equal (rgData[0] * 2 + 1). rgData[1] - (string) name of the first browse element. rgData[2] - (number) adt of the first browse element. rgData[1 + n * 2] - (string) name of the n'th browse element. rgData[2 + n * 2] - (number) adt of the n'th browse element. - The XMC_DE_BROWSE_GET_ITEMS method returns the number of data items in the browse set supported by the component.
-
- XMC_DE_SYSTEM_CONNECT_CMPNT
-
Index 8000 Data In rgData[0] - (number) DWORD, type of component. The type of component is a value that is server specific. For component type information, see the description for this method under each server's description. rgData[1] - (string) LPTSTR, component class id as an ASCII string. Data Out None. - The XMC_DE_SYSTEM_CONNECT_CMPNT method is used to connect one server to another so that they may interact with one another.
-
- XMC_DE_SYSTEM_DISCONNECT_CMPNT
-
Index 8001 Data In rgData[0] - (number) DWORD, type of component. The type of component is a value that is server specific. For component type information, see the description for this method under each server's description. rgData[1] - (string) LPTSTR, component class id as an ASCII string. Data Out None. - The XMC_DE_SYSTEM_DISCONNECT_CMPNT method is used to disconnect one server to another so that they stop interacting with one another.
-
- XMC_DE_DATA_PROCESS
-
Index 8063 Data In rgData[0] - (number) DWORD, number of data items input. rgData[1 + n * 2] - (string) LPCTSTR, name of the data item input. rgData[2 + n * 2] - (number or string), value of the data item. Data Out rgData[0] - (number) DWORD, number of data items output. rgData[1 + n * 2] - (string) LPCTSTR, name of the data item output. rgData[2 + n * 2] - (number) value of the data item. - The XMC_DE_DATA_PROCESS method is called by a client to process data where a data set is input, processed in some way by the server, and then the resulting data is returned as output.
-
- XMC_DE_DATA_PROCESS_CONFIGURE
-
Index 8062 Data In rgData[0] - (number) DWORD, flag describing the type of data to be returned when processing data. The following flags are supported: XMC_DE_READ_DATA_FLAG_TIMESTAMP - requests that the time stamp recorded when processing the data is returned. NOTE: by default, the data item value is always returned. Data None. Out - The XMC_DE_DATA_PROCESS_CONFIGURE method is used to configure what type of data is returned when processing a given data item. For example in the server may be configured to return the minimal amount of data on each read (i.e. just the data item value), or the server may be requested to return more substantial data.
-
- XMC_DE_DATA_READ
-
Index 8061 Data In rgData[0] - (string) LPCTSTR, name of the data item to read. Data Out rgData[0] - (number or string), data item value. rgData[1] - (OPTIONAL number) DWORD, data item time- stamp as a system time value. NOTE: Since the last items are optional, only those items specified when configuring the data to receive are actually sent. - The XMC_DE_DATA_READ method is called by a client application to poll for data from the server. As used herein, the term “poll” refers to the process of continually reading a data item so that the most recent value of the data is always on hand.
-
- XMC_DE_DATA_READ_CONFIGURE
-
Index 8060 Data In rgData[0] - (number) DWORD, flag describing the type of data to be returned on each read. The following flags are supported: XMC_DE_READ_DATA_FLAG_TIMESTAMP - requests that the time stamp recorded when reading the data is returned. NOTE: by default, the data item value is always returned. Data None. Out - The XMC_DE_DATA_READ_CONFIGURE method is used to configure what type of data is returned when reading a given data item. For example in the server may be configured to return the minimal amount of data on each read (i.e. just the data item value), or the server may be requested to return more substantial data.
-
- XMC_DE_DATA WRITE
-
Index 8064 Data In rgData[0] - (number) DWORD, number of data items. rgData[1 + n * 2] - (string) LPCTSTR, name of the data item. rgData[2 + n * 2] - (number or string), value of the data item. Data Out None. - The XMC_DE_DATA WRITE method is used to write data to a server.
-
- XMC_DE_EVENT ENABLE
-
Index 2892 Data In rgData[0] - (number) DWORD, cookie (unique identifier) associated with the subscription. This value is returned to the client when calling the subscription XMCAPI above. NOTE: using a cookie value of zero (0) will enable/disable ALL items subscribed to the server. rgData[1] - (number) BOOL, TRUE to enable the subscription(s), FALSE to disable the subscription(s). Only enabled subscriptions actually fire events. Data Out None. - The XMC_DE_EVENT ENABLE method enables/disables a previously subscribed data item in the subscription list maintained by the server. Only enabled subscriptions actually fire.
-
- XMC_DE EVENT_RECEIVE_DATA
-
Index 8045 Data In rgData[0] - (number) DWORD, subscription cookie corresponding to the subscribed data item. rgData[1] - (number or string), data item value. rgData[2] - (OPTIONAL number) DWORD, data item time- stamp as a system time value. rgData[3] - (OPTIONAL string) LPSTR, data item ASCII text name. rgData[4] - (OPTIONAL number) DWORD, data item unique cookie. NOTE: Since the last three items are optional, only those items specified when configuring the data to receive are actually sent. If, for example, one or more data items are NOT requested, then the items are returned in slots shifted up toward rgData[1]. For example if only the data item name is requested in addition to the default data items, the data returned would look like the following: rgData[0] - (number) DWORD, subscription cookie. rgData[1] - (number or string), data item value. rgData[2] - (string) LPSTR, data item name. Data Out None. - The XMC_DE_EVENT_RECEIVE_DATA method is called by the server (and implemented by the client) when each subscribed event fires.
-
- XMC_DE_EVENT_RECEIVE_DATA_CONFIGURE
-
Index 8044 Data In rgData[0] - (number) DWORD, flag describing the type of data to be returned on each event. The following flags are supported: XMC_DE_EVENT_DATA_FLAG_TIMESTAMP - requests that the time stamp recorded when reading the data is returned. XMC_DE_EVENT_DATA_FLAG_NAME - requests that the data items ASCII text name be returned. XMC_DE_EVENT_DATA_FLAG_DATA_COOKIE - requests that the unique data item cookie corresponding to the read made for the data item be returned. NOTE: by default, the subscription cookie and data item value are always returned. Data Out None. - The XMC_DE_EVENT_RECEIVE_DATA_CONFIGURE method is used to configure what type of data is returned on each event that is fired. For example in the server may be configured to send the minimal amount of data on each event (i.e. subscription cookie and data item value), or the server may be requested to return more substantial data.
-
- XMC_DE_EVENT_SUBSCRIBE
-
Index 2890 Data rgData[0] - (number) DWORD, flags describing the initial In state of the subscription. The following flags are supported: XMC_DE_EVENT_FLAG_ENABLED - subscription is immediately enabled upon subscription. XMC_DE_EVENT_FLAG_DISABLED - subscription is disabled upon making the subscription. The Enable function must be called to enable the subscription. rgData[1] - (number) DWORD, number of subscription criteria rules. rgData[2 + (2 * n)] - (number) DWORD, event condition type where the following types are supported: XMC_CNC_EVENTCONDITION_DATA_CHANGE - any data changes in the data type above will trigger the event. XMC_CNC_EVENTCONDITION_DATA_EQUAL XMC_CNC_EVENTCONDITION_DATA_LESSTHAN XMC_CNC_EVENTCONDITION_DATA_GREATERTHAN XMC_CNC_EVENTCONDITION_DATA_AND XMC_CNC_EVENTCONDITION_DATA_OR Each of the conditions above are used in a combined manner. Where the logical condition (=, <, >) are applied for each type respectively. For example, in an array that contains the following items: rgData[2] = 4 (4 condition values) rgData[3] = XMC_CNC_EVENTCONDITION_EQUAL rgData[4] = 3.0 rgData[5] = XMC_CNC_EVENTCONDITION_LESSTHAN rgData[6] = 3.0 rgData[7] = XMC_CNC_EVENTCONDITION_OR rgData[8] = 1.0 rgData[9] = XMC_CNC_EVENTCONDITION_GREATHERTHAN rgData[10] = 5.0 the array would be evaluated using the following logic: If (DATA <= 3.0 OR DATA > 5.0) then Trigger Event rgData[3 + (2 * n)] - (number) double, the value for the condition. See above. Data rgData[0] - (number) DWORD, cookie (unique identifier) Out representing the subscription. - The XMC_DE_EVENT_SUBSCRIBE method subscribes to a given data item activating the event interface when the subscription criteria are met for the data item. All subscribing components must use the IXMCDirect interface to receive events received from the server for which they are subscribed.
-
- XMC_DE_EVENT_UNSUBSCRIBE
-
Index 2891 Data In rgData[0] - (number) DWORD, cookie (unique identifier) associated with the subscription. This value is returned to the client when calling the subscription XMCAPI above. NOTE: using a cookie value of zero (0) will unsubscribe ALL items subscribed to the server. Data Out None. - The XMC_DE_EVENT_UNSUBSCRIBE method removes a previously subscribed data item from the subscription list maintained by the server.
-
- XMC_DE_SYSTEM_INITIALIZEHW
-
Index 500 Data In None. Data Out None. - The XMC_DE_SYSTEM_INITIALIZEHW method is used to initialize any hardware systems associated with the component.
-
- XMC_DE_SYSTEM_SHUTDOWNHW
-
Index 501 Data In None. Data Out None. - The XMC_DE_SYSTEM_SHUTDOWNHW method is used to shutdown any hardware systems associated with the component.
- The
event handler 230 component implements the following general methods listed in the General Component Methods section above. -
Not Method Implemented Implemented XMC_DE_BROWSE_GET_COUNT x XMC_DE_BROWSE_GET_ITEMS x XMC_DE_DATA_PROCESS x XMC_DE_DATA_PROCESS_CONFIGURE x XMC_DE_DATA_READ x XMC_DE_DATA_READ_CONFIGURE x XMC_DE_DATA_WRITE x XMC_DE_EVENT_ENABLE x XMC_DE_EVENT_RECEIVE_DATA x XMC_DE_EVENT_RECEIVE_DATA_CONFIGURE x XMC_DE_EVENT_SUBSCRIBE* x XMC_DE_EVENT_UNSUBSCRIBE* x XMC_DE_SYSTEM_CONNECT_CMPNT x XMC_DE_SYSTEM_DISCONNECT_CMPNT x XMC_DE_SYSTEM_INITIALIZEHW x XMC_DE_SYSTEM_SHUTDOWNHW x - The following methods have special notes for this component. The XMC_DE_EVENT_SUBSCRIBE method is only needed when daisy chaining components together. The XMC_DE_EVENT_UNSUBSCRIBE method is only needed when daisy chaining components together.
- The visual elements presented by the
event handler 230 component, namely the eventhandler property pages 234, will now be described in further detail. - The example property page depicted in
FIG. 19 allows the user to set-up the connection settings used to connect to the target machine from which data will be received. In addition, this property page allows the user to configure how the component is connected and starts-up when it is first run. - As shown in
FIG. 19 , the following user interface elements form the connection and start-upproperty page 320. A “target machine”field 322 identifies thetarget machine 222 from which data is to be received using the TARGETMACHINE method. A “connect”button 324 tests the connection with the target machine using a CONNECT method. A “disconnect”button 326 disconnects thesystem 224 from thetarget machine 222 using the DISCONNECT method. - A “map variables”
check box 328 specifies whether or not to load mapped variables from a file when connecting using OPTIONS, (OF_MAPVARIABLES_ENABLED), and VARMAPFILE properties. When checked, a dialog appears allowing the user to select the file to load mapped variables from. - An “enable auto load”
check box 330 specifies whether or not the auto load feature should be enabled and, when enabled, from which file to load the settings from as identified in a “file”field 332 using OPTIONS, (OF_AUTOLOAD_ENABLED), CONFIGFILE properties. - An “enable auto start”
check box 334 specifies whether or not to enable auto start using OPTIONS (OF_AUTOSTART_ENABLED) properties. - An event monitoring
property page 340 depicted inFIG. 20 allows the user to configure which variables are to be monitored. The eventmonitoring property page 340 comprises the following interface elements. - A “variables”
box 342 contains a list of all variables that are available for monitoring. A “test”button 344 directs the application to test a selected (highlighted) variable by reading it using a READ method. An “attributes” 346 button retrieves the attributes of the selected (highlighted) variable using the READ(‘attrib’) method. - A “variables” (to monitor)
box 350 contains a list of all variables that have been selected for monitoring using VAR_MONITOR_COUNT and VAR_MONITOR_properties. - A first “add . . . ”
button 352 directs theevent handler 330 to add a variable from the “variable” list in thebox 342 to the “variables (to monitor)” list in thebox 350. A first “remove”button 354 directs theevent handler 330 to remove the selected variable from the “variables (to monitor)” list in thebox 350. When a first “all”check box 356 is checked, pressing the first “remove”button 354 directs theevent handler 330 to remove all variables from the “variables (to monitor)”list box 350. - A “variables (to read)”
box 360 contains a list of all variables that have been selected for reading using VAR_READ_COUNT and VAR_READ_properties. A second “add . . . ”button 362 directs theevent handler 330 to add a variable from the “variable” list in thebox 342 to the “variables (to read)” list in thebox 360. A second “remove”button 354 directs theevent handler 330 to remove the selected variable from the “variables (to read)” list in thebox 360. When a second “all”check box 366 is checked, pressing the second “remove”button 364 directs theevent handler 330 to remove all variables from the “variables (to read)”list box 360. - Referring now to
FIG. 21 , depicted therein is an example of a datacollection property page 370 that allows the user to specify how the variable data is collected. The datacollection property page 370 comprises the following user interface elements. - A “queue event results up to:”
check box 372 and associatededit field 374 specify the maximum number of items to be placed in theoptional data queue 236 using the following properties: OPTIONS (OF_QUEUE_API_CALLS_ENABLED), OPTIONS (OF_QUEUE_EVENTS_ENABLED), and QUEUEMAXSIZE. - A “wait for data received event:”
check box 374 and associatededit field 374 specify the amount of time to wait for the recipient of the data to respond by signaling the data ready event using the following properties: OPTIONS (OF_WAIT_FOR_DATA_RECEIVED) and DATARECEIVEDTIMEOUT method. - A “delete old items after:”
check box 380 and associatededit field 372 specify the amount of time that data items may remain in the queue after which they are purged, using the following properties: OPTIONS (OF_DELETE_OLD_QUEUE_ITEMS) and DATAOLDTIMEOUT method. - The “collect data always”
check box 384 specifies whether or not data should always be collected, even when the data does not change, using the following properties: OPTIONS (OP_COLELCT_DATA_ALWAYS). - The present invention may be embodied in forms other than those described above. The scope of the present invention should thus be determined with reference to the following claims and not the foregoing exemplary detailed description.
- This Appendix A contains the definitions of all special types used by the methods and properties of each component making up the example XMC Program Engine system that may form a part of the present invention.
- All methods exposed by each component in the XMC Program Engine system use the standard XMC parameters set to describe data used to set and query properties as well as invoke methods. The standard parameters are in the following format:
- pObj->InvokeMethod(LPXMC_PARAM_DATA rgData, DWORD dwCount);
- Each element in the rgData array corresponds to a parameter, with the first element in the array corresponding to the first parameter. The XMC_PARAM_DATA structure can contain either a numerical or a string value and is defined as follows:
-
typedef struct tagXMC_PARAM_DATA { LNG_PARAM_DATATYPE adt; union { double df; LPTSTR psz; }; }XMC_PARAM_DATA; - The ‘adt’ member of the XMC_PARAM_DATA structure describes the data contained within the XMC_PARAM_DATA structure. The values are described below:
-
LNG_PARAM_DATATYPE Description LNG_ADT_NUMBER Use this value when passing a numerical value via the ‘adt’ member of the XMC_PARAM_DATA structure. LNG_ADT_STAT_STRING Use this value when passing a static string value via the ‘psz’ member of the XMC_PARAM_DATA structure. Static strings do not need to be freed from memory. LNG_ADT_MEM_STRING Use this value when passing a string value via the ‘psz’ member of the XMC_PARAM_DATA structure. LNG_ADT_MEM_STRING denotes that the string must be freed from memory during cleanup. LNG_ADT_NOP This value is used to ignore items within the XMC_PARAM_DATA array. When specifies, this parameter is not used. - When querying and setting boolean TRUE/FALSE values, any non-zero value is considered TRUE, whereas a zero value is considered FALSE.
Claims (41)
1. A motion system comprising:
a network;
a set of controller independent media commands;
a set of event tokens;
a set of motion events each associated with at least one event token;
a set of motion media each comprising at least one media command;
a motion control device;
a motion control component capable of executing motion media to command at least one motion control device;
a motion event manager that associates at least one event token with at least one motion media; whereby
the motion event manager instructs the motion control component to command at least one motion control device after receiving across the network at least one event token associated with at least one motion event.
2. A system as recited in claim 1 , where in at least one motion event is a text event.
3. A system as recited in claim 2 , where in at least one text event is communicated from an instant messaging service.
4. A system as recited in claim 3 , where in at least one text event is communicated by E-mail.
5. A system as recited in claim 1 , where in at least one motion event is associated with a person speaking.
6. A system as recited in claim 1 , where in at least one motion event is associated with a user action.
7. A system as recited in claim 1 , where in at least one motion event is associated with an operating system event.
8. A system as recited in claim 1 , where in at least one motion event is associated with an event from a third-party software application.
9. A system as recited in claim 1 , where in at least one motion media is comprised of scripts.
10. A system as recited in claim 1 , where in at least one motion media contains at least one controller dependent command.
11. A system as recited in claim 1 , where in the motion event manager associates at least one motion media with at least one event token.
12. A system as recited in claim 1 , further comprising at least one event provider that generates at least one event token.
13. A system as recited in claim 1 , where in the network is a wireless network.
14. A system as recited in claim 1 , where in the network is a packet-based network.
15. A system as recited in claim 1 , where in the network is associated with the Internet.
16. A system as recited in claim 13 , where in the wireless network uses WiFi.
17. A system as recited in claim 1 , where in the network is configured as a peer-to-peer network.
18. A system as recited in claim 1 , further comprising a media creation tool configured to create motion media.
19. A system as recited in claim 18 , where in the media creation tool is capable of creating motion media with recorded operations.
20. A system as recited in claim 18 , where in the media creation tool is capable of creating motion media with drag-drop operations.
21. A motion system comprising:
a set of controller independent media commands;
a set of event tokens;
a set of motion events each associated with at least one event token;
a set of motion media each comprising at least one media command;
a motion control device;
a motion control component capable of executing motion media to command at least one motion control device;
a motion event manager that associates at least one event token with at least one motion media; whereby
the motion event manager instructs the motion control component to command at least one motion control device after receiving at least one event token associated with at least one motion event.
22. A system as recited in claim 21 , where in at least one motion event is a text event.
23. A system as recited in claim 22 , where in at least one text event is communicated from an instant messaging service.
24. A system as recited in claim 23 , where in at least one text event is communicated by E-mail.
25. A system as recited in claim 21 , where in at least one motion event is associated with a person speaking.
26. A system as recited in claim 21 , where in at least one motion event is associated with a user action.
27. A system as recited in claim 21 , where in at least one motion event is associated with an operating system event.
28. A system as recited in claim 21 , where in at least one motion event is associated with an event from a third-party software application.
29. A system as recited in claim 21 , where in at least one motion media is comprised of scripts.
30. A system as recited in claim 21 , where in at least one motion media contains at least one controller dependent command.
31. A system as recited in claim 21 , where in the Event Manager associates at least one motion media with at least one event token.
32. A system as recited in claim 21 , further comprising at least one event provider that generates at least one event token.
33. A system as recited in claim 21 , where in at least one event token is transferred across a network to the Event Manager.
34. A system as recited in claim 33 , where in the network is a wireless network.
35. A system as recited in claim 33 , where in the network is a packet-based network.
36. A system as recited in claim 33 , where in the network is associated with the Internet.
37. A system as recited in claim 34 , where in the wireless network uses WiFi.
38. A system as recited in claim 33 , where in the network is configured as a peer-to-peer network.
39. A system as recited in claim 21 , further comprising a media creation tool configured to create motion media.
40. A system as recited in claim 39 , where in the media creation tool is capable of creating motion media with recorded operations.
41. A system as recited in claim 39 , where in the media creation tool is capable of creating motion media with drag-drop operations.
Priority Applications (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US13/719,112 US20130110259A1 (en) | 2001-02-09 | 2012-12-18 | Event Management Systems and Methods for Motion Control Systems |
US14/572,611 US20150105869A1 (en) | 2001-02-09 | 2014-12-16 | Event Management Systems and Methods for Motion Control Systems |
Applications Claiming Priority (7)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US26764501P | 2001-02-09 | 2001-02-09 | |
US10/074,577 US7031798B2 (en) | 2001-02-09 | 2002-02-11 | Event management systems and methods for the distribution of motion control commands |
US65874605P | 2005-03-03 | 2005-03-03 | |
US36823106A | 2006-03-03 | 2006-03-03 | |
US11/728,801 US7904194B2 (en) | 2001-02-09 | 2007-03-26 | Event management systems and methods for motion control systems |
US12/896,750 US20110071652A1 (en) | 2001-02-09 | 2010-10-01 | Event Management Systems and Methods for Motion Control Systems |
US13/719,112 US20130110259A1 (en) | 2001-02-09 | 2012-12-18 | Event Management Systems and Methods for Motion Control Systems |
Related Parent Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US12/896,750 Continuation US20110071652A1 (en) | 2001-02-09 | 2010-10-01 | Event Management Systems and Methods for Motion Control Systems |
Related Child Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US14/572,611 Continuation US20150105869A1 (en) | 2001-02-09 | 2014-12-16 | Event Management Systems and Methods for Motion Control Systems |
Publications (1)
Publication Number | Publication Date |
---|---|
US20130110259A1 true US20130110259A1 (en) | 2013-05-02 |
Family
ID=46150499
Family Applications (4)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US11/728,801 Expired - Fee Related US7904194B2 (en) | 2001-02-09 | 2007-03-26 | Event management systems and methods for motion control systems |
US12/896,750 Abandoned US20110071652A1 (en) | 2001-02-09 | 2010-10-01 | Event Management Systems and Methods for Motion Control Systems |
US13/719,112 Abandoned US20130110259A1 (en) | 2001-02-09 | 2012-12-18 | Event Management Systems and Methods for Motion Control Systems |
US14/572,611 Abandoned US20150105869A1 (en) | 2001-02-09 | 2014-12-16 | Event Management Systems and Methods for Motion Control Systems |
Family Applications Before (2)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US11/728,801 Expired - Fee Related US7904194B2 (en) | 2001-02-09 | 2007-03-26 | Event management systems and methods for motion control systems |
US12/896,750 Abandoned US20110071652A1 (en) | 2001-02-09 | 2010-10-01 | Event Management Systems and Methods for Motion Control Systems |
Family Applications After (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US14/572,611 Abandoned US20150105869A1 (en) | 2001-02-09 | 2014-12-16 | Event Management Systems and Methods for Motion Control Systems |
Country Status (1)
Country | Link |
---|---|
US (4) | US7904194B2 (en) |
Cited By (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US9588510B2 (en) | 2003-09-25 | 2017-03-07 | Automation Middleware Solutions, Inc. | Database event driven motion systems |
US9915934B2 (en) | 1999-05-04 | 2018-03-13 | Automation Middleware Solutions, Inc. | Systems and methods for communicating with motion control systems and devices |
TWI709833B (en) * | 2018-09-20 | 2020-11-11 | 日商斯庫林集團股份有限公司 | Data processing method, data processing device, and computer-readable recording medium |
Families Citing this family (36)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20100131081A1 (en) * | 1995-05-30 | 2010-05-27 | Brown David W | Systems and methods for motion control |
US5691897A (en) * | 1995-05-30 | 1997-11-25 | Roy-G-Biv Corporation | Motion control systems |
US7904194B2 (en) * | 2001-02-09 | 2011-03-08 | Roy-G-Biv Corporation | Event management systems and methods for motion control systems |
US20070094599A1 (en) * | 2005-09-08 | 2007-04-26 | Heidelberger Druckmaschinen Aktiengesellschaft | Method and system for training an operator of a paper folding machine |
DE102006008261A1 (en) * | 2006-02-22 | 2007-08-30 | Fraunhofer-Gesellschaft zur Förderung der angewandten Forschung e.V. | Etching solution for etching layer system, comprising phosphoric acid, nitric acid, de-ionized water and halogen component, which releases halogen ions that contain these components |
BRPI0716194A2 (en) * | 2006-09-05 | 2013-11-12 | Sunnen Products Co | AUTOMATIC CONTROL OF MACHINE PARAMETERS COMPLETELY INTEGRATING A MACHINE CONTROL CALIBRATION SYSTEM |
US20090094614A1 (en) * | 2007-10-05 | 2009-04-09 | Microsoft Corporation | Direct synchronous input |
US7769806B2 (en) | 2007-10-24 | 2010-08-03 | Social Communications Company | Automated real-time data stream switching in a shared virtual area communication environment |
US8397168B2 (en) | 2008-04-05 | 2013-03-12 | Social Communications Company | Interfacing with a spatial virtual communication environment |
US9853922B2 (en) | 2012-02-24 | 2017-12-26 | Sococo, Inc. | Virtual area communications |
US20100306825A1 (en) | 2009-05-27 | 2010-12-02 | Lucid Ventures, Inc. | System and method for facilitating user interaction with a simulated object associated with a physical location |
US8483864B2 (en) * | 2009-06-20 | 2013-07-09 | Production Resource Group Llc | Stage effects console for stage controlling system |
US9529648B2 (en) * | 2009-06-26 | 2016-12-27 | International Business Machines Corporation | Generic declaration of bindings between events and event handlers regardless of runtime structure |
US20110169832A1 (en) * | 2010-01-11 | 2011-07-14 | Roy-G-Biv Corporation | 3D Motion Interface Systems and Methods |
US9218316B2 (en) | 2011-01-05 | 2015-12-22 | Sphero, Inc. | Remotely controlling a self-propelled device in a virtualized environment |
US10281915B2 (en) | 2011-01-05 | 2019-05-07 | Sphero, Inc. | Multi-purposed self-propelled device |
US9090214B2 (en) | 2011-01-05 | 2015-07-28 | Orbotix, Inc. | Magnetically coupled accessory for a self-propelled device |
US9429940B2 (en) | 2011-01-05 | 2016-08-30 | Sphero, Inc. | Self propelled device with magnetic coupling |
EP2661311B8 (en) | 2011-01-05 | 2019-12-11 | Sphero, Inc. | Self-propelled device with actively engaged drive system |
US20120244969A1 (en) | 2011-03-25 | 2012-09-27 | May Patents Ltd. | System and Method for a Motion Sensing Device |
US9037282B2 (en) | 2011-06-24 | 2015-05-19 | The Boeing Company | Manufacturing control system |
WO2013078062A1 (en) * | 2011-11-23 | 2013-05-30 | Social Communications Company | Creating and managing virtual areas |
WO2013099031A1 (en) * | 2011-12-28 | 2013-07-04 | 株式会社安川電機 | Engineering tool |
US20130297460A1 (en) | 2012-05-01 | 2013-11-07 | Zambala Lllp | System and method for facilitating transactions of a physical product or real life service via an augmented reality environment |
CN104428791A (en) | 2012-05-14 | 2015-03-18 | 澳宝提克斯公司 | Operating a computing device by detecting rounded objects in an image |
US9827487B2 (en) | 2012-05-14 | 2017-11-28 | Sphero, Inc. | Interactive augmented reality using a self-propelled device |
US9292758B2 (en) | 2012-05-14 | 2016-03-22 | Sphero, Inc. | Augmentation of elements in data content |
US10056791B2 (en) | 2012-07-13 | 2018-08-21 | Sphero, Inc. | Self-optimizing power transfer |
US9342063B1 (en) * | 2013-09-19 | 2016-05-17 | Amazon Technologies, Inc. | Determining capacities of work buffers |
US9829882B2 (en) | 2013-12-20 | 2017-11-28 | Sphero, Inc. | Self-propelled device with center of mass drive system |
KR20160091626A (en) * | 2015-01-26 | 2016-08-03 | 한국전자통신연구원 | Method and apparatus for controlling life-cycle of process for network operating system |
US9733922B2 (en) * | 2015-07-06 | 2017-08-15 | International Business Machines Corporation | Smarter operating systems: file system events |
US9690894B1 (en) * | 2015-11-02 | 2017-06-27 | Altera Corporation | Safety features for high level design |
US10223176B1 (en) * | 2017-10-13 | 2019-03-05 | Amazon Technologies, Inc. | Event handler nodes for visual scripting |
CN112799863B (en) * | 2019-11-13 | 2024-07-09 | 北京百度网讯科技有限公司 | Method and device for outputting information |
US12145066B2 (en) * | 2020-04-07 | 2024-11-19 | CEO Vision, Inc | Systems and methods for an object movement engine in a gaming environment |
Citations (19)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5691897A (en) * | 1995-05-30 | 1997-11-25 | Roy-G-Biv Corporation | Motion control systems |
US6292712B1 (en) * | 1998-01-29 | 2001-09-18 | Northrop Grumman Corporation | Computer interface system for a robotic system |
US6292714B1 (en) * | 2000-05-12 | 2001-09-18 | Fujitsu Limited | Robot cooperation device, and robot cooperation program storage medium |
US20020103575A1 (en) * | 2001-01-30 | 2002-08-01 | Tomoyoshi Sugawara | Program executing method, system and program processing unit for robot |
US6480896B1 (en) * | 1999-10-27 | 2002-11-12 | Roy-G-Biv Corporation | Systems and methods for generating and communicating motion data through a distributed network |
US6513058B2 (en) * | 1995-05-30 | 2003-01-28 | Roy-G-Biv Corporation | Distribution of motion control commands over a network |
US6522951B2 (en) * | 1999-12-09 | 2003-02-18 | Kuka Roboter Gmbh | Method and device for controlling a robot |
US6529802B1 (en) * | 1998-06-23 | 2003-03-04 | Sony Corporation | Robot and information processing system |
US6542925B2 (en) * | 1995-05-30 | 2003-04-01 | Roy-G-Biv Corporation | Generation and distribution of motion commands over a distributed network |
US20040093219A1 (en) * | 2002-11-13 | 2004-05-13 | Ho-Chul Shin | Home robot using home server, and home network system having the same |
US20040098167A1 (en) * | 2002-11-18 | 2004-05-20 | Sang-Kug Yi | Home robot using supercomputer, and home network system having the same |
US6885898B1 (en) * | 2001-05-18 | 2005-04-26 | Roy-G-Biv Corporation | Event driven motion systems |
US7024666B1 (en) * | 2002-01-28 | 2006-04-04 | Roy-G-Biv Corporation | Motion control systems and methods |
US7031798B2 (en) * | 2001-02-09 | 2006-04-18 | Roy-G-Biv Corporation | Event management systems and methods for the distribution of motion control commands |
US7137107B1 (en) * | 2003-04-29 | 2006-11-14 | Roy-G-Biv Corporation | Motion control systems and methods |
US7139642B2 (en) * | 2001-11-07 | 2006-11-21 | Sony Corporation | Robot system and robot apparatus control method |
US7139843B1 (en) * | 1995-05-30 | 2006-11-21 | Roy-G-Biv Corporation | System and methods for generating and communicating motion data through a distributed network |
US20100131080A1 (en) * | 1999-10-27 | 2010-05-27 | Roy-G-Biv Corporation | Event Driven Motion Systems |
US7949616B2 (en) * | 2004-06-01 | 2011-05-24 | George Samuel Levy | Telepresence by human-assisted remote controlled devices and robots |
Family Cites Families (335)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US4829419A (en) | 1970-12-28 | 1989-05-09 | Hyatt Gilbert P | Microcomputer control of machines |
US4531182A (en) | 1969-11-24 | 1985-07-23 | Hyatt Gilbert P | Machine control system operating from remote commands |
US4078195A (en) | 1976-01-13 | 1978-03-07 | Macotech Corporation | Adaptive control system for numerically controlled machine tools |
US4092532A (en) * | 1976-11-10 | 1978-05-30 | The United Sates Of America As Represented By The Secretary Of The Navy | Binary apparatus for motion control |
US4199814A (en) | 1977-10-12 | 1980-04-22 | Digitcom, Inc. | Computer numerical control machine tool |
US4159417A (en) | 1977-10-28 | 1979-06-26 | Rubincam David P | Electronic book |
US4422150A (en) | 1980-05-23 | 1983-12-20 | The Boeing Company | Machine tool controller and part inspection monitor |
US4418381A (en) | 1981-01-23 | 1983-11-29 | Bristol Babcock Inc. | Single loop control system |
US4444061A (en) | 1982-03-26 | 1984-04-24 | Camtech Inc. | Force and torque sensor for machine tools |
US4800521A (en) | 1982-09-21 | 1989-01-24 | Xerox Corporation | Task control manager |
US4688195A (en) | 1983-01-28 | 1987-08-18 | Texas Instruments Incorporated | Natural-language interface generating system |
US4494060A (en) | 1983-03-02 | 1985-01-15 | Anorad Corporation | Axis controller for robotic actuator |
US4799171A (en) * | 1983-06-20 | 1989-01-17 | Kenner Parker Toys Inc. | Talk back doll |
US4563906A (en) | 1983-11-23 | 1986-01-14 | Camtech, Inc. | Load measurement apparatus including miniature instrumented hydrostatic cell |
FR2556866B1 (en) | 1983-12-15 | 1987-08-21 | Giravions Dorand | METHOD AND DEVICE FOR DRIVING DRIVING MOBILE MACHINES. |
NL8400186A (en) | 1984-01-20 | 1985-08-16 | Philips Nv | PROCESSOR SYSTEM CONTAINING A NUMBER OF STATIONS CONNECTED BY A COMMUNICATION NETWORK AND STATION FOR USE IN SUCH A PROCESSOR SYSTEM. |
JPS60186808A (en) * | 1984-03-06 | 1985-09-24 | Sumitomo Chem Co Ltd | Optical transmission fiber |
US4713808A (en) | 1985-11-27 | 1987-12-15 | A T & E Corporation | Watch pager system and communication protocol |
JPH0782498B2 (en) | 1985-01-14 | 1995-09-06 | 株式会社日立製作所 | Machine translation system |
CA1244555A (en) | 1985-06-17 | 1988-11-08 | Walter H. Schwane | Process transparent multi storage mode data transfer and buffer control |
US4809335A (en) | 1985-10-24 | 1989-02-28 | Rumsey Daniel S | Speech unit for dolls and other toys |
US4767334A (en) | 1985-11-19 | 1988-08-30 | Thorne Hugh C | Educational and recreational toy vehicle |
US4897835A (en) | 1985-11-27 | 1990-01-30 | At&E Corporation | High capacity protocol with multistation capability |
US4782444A (en) | 1985-12-17 | 1988-11-01 | International Business Machine Corporation | Compilation using two-colored pebbling register allocation method such that spill code amount is invariant with basic block's textual ordering |
JP2525358B2 (en) | 1986-01-25 | 1996-08-21 | フアナツク株式会社 | Robot controller |
US4937759A (en) | 1986-02-18 | 1990-06-26 | Robotics Research Corporation | Industrial robot with controller |
US4843566A (en) | 1986-03-07 | 1989-06-27 | Hewlett-Packard Company | Robot motion control system |
US4853877A (en) | 1986-04-21 | 1989-08-01 | Hewlett-Packard Company | Apparatus and method for efficient plotting |
JPS6318403A (en) | 1986-07-10 | 1988-01-26 | Fanuc Ltd | Off-line control executing method |
US4868474A (en) | 1986-11-20 | 1989-09-19 | Westinghouse Electric Corp. | Multiprocessor position/velocity servo control for multiaxis digital robot control system |
US4829219A (en) | 1986-11-20 | 1989-05-09 | Unimation Inc. | Multiaxis robot having improved motion control through variable acceleration/deceleration profiling |
EP0275826A1 (en) | 1986-12-16 | 1988-07-27 | Ciba-Geigy Ag | Control system for a sample preparation system |
US4846693A (en) | 1987-01-08 | 1989-07-11 | Smith Engineering | Video based instructional and entertainment system using animated figure |
US4857030A (en) | 1987-02-06 | 1989-08-15 | Coleco Industries, Inc. | Conversing dolls |
US4840602A (en) | 1987-02-06 | 1989-06-20 | Coleco Industries, Inc. | Talking doll responsive to external signal |
CA1338909C (en) | 1987-03-05 | 1997-02-11 | Curtis M. Brubaker | Radio control toy |
US4716458A (en) | 1987-03-06 | 1987-12-29 | Heitzman Edward F | Driver-vehicle behavior display apparatus |
EP0283295B1 (en) | 1987-03-20 | 1993-09-08 | Canon Kabushiki Kaisha | Data communication system |
US4852047A (en) | 1987-04-14 | 1989-07-25 | Universal Automation Inc. | Continuous flow chart, improved data format and debugging system for programming and operation of machines |
JPS63273105A (en) | 1987-04-30 | 1988-11-10 | Fanuc Ltd | Numerical controller |
JPH0679290B2 (en) | 1987-05-31 | 1994-10-05 | 日本電気株式会社 | Computer device |
US4901218A (en) | 1987-08-12 | 1990-02-13 | Renishaw Controls Limited | Communications adaptor for automated factory system |
US4855725A (en) | 1987-11-24 | 1989-08-08 | Fernandez Emilio A | Microprocessor based simulated book |
US4989253A (en) * | 1988-04-15 | 1991-01-29 | The Montefiore Hospital Association Of Western Pennsylvania | Voice activated microscope |
US5025385A (en) | 1988-04-15 | 1991-06-18 | Froyd Stanley G | Multiple axis motion control system |
US4923428A (en) | 1988-05-05 | 1990-05-08 | Cal R & D, Inc. | Interactive talking toy |
DE58909756D1 (en) | 1988-06-17 | 1997-02-06 | Siemens Ag | Method and arrangement for executing a program in a heterogeneous multi-computer system |
FR2633414B1 (en) | 1988-06-27 | 1993-07-09 | Bull Sa | COMPUTER SYSTEM WITH CENTRAL INTERCONNECTION |
US4887966A (en) | 1988-06-30 | 1989-12-19 | Gellerman Floyd R | Flight simulation control apparatus |
US5309351A (en) | 1988-10-27 | 1994-05-03 | Texas Instruments Incorporated | Communications, information, maintenance diagnostic and training system |
US5230049A (en) | 1988-11-29 | 1993-07-20 | International Business Machines Corporation | Program source code translator |
US5014208A (en) | 1989-01-23 | 1991-05-07 | Siemens Corporate Research, Inc. | Workcell controller employing entity-server model for physical objects and logical abstractions |
US5005135A (en) | 1989-03-22 | 1991-04-02 | Cincinnati Milacron, Inc. | Dynamic correction of servo following errors in a computer-numerically controlled system and fixed cycle utilizing same |
US5119318A (en) | 1989-04-17 | 1992-06-02 | Del Partners L.P. | Expert control system for real time management of automated factory equipment |
JP2982010B2 (en) | 1989-06-23 | 1999-11-22 | 三菱電機株式会社 | Numerical control method and device |
JP2784811B2 (en) | 1989-08-25 | 1998-08-06 | ソニー株式会社 | Image creation device |
US5247650A (en) | 1989-08-30 | 1993-09-21 | Industrial Technology Institute | System for combining originally software incompatible control, kinematic, and discrete event simulation systems into a single integrated simulation system |
US5175817A (en) | 1989-11-20 | 1992-12-29 | Digital Equipment Corporation | Data representation protocol for communications between different networks |
JPH0727505B2 (en) | 1990-02-12 | 1995-03-29 | インターナショナル・ビジネス・マシーンズ・コーポレイション | Interface method and interface system |
GB9007661D0 (en) | 1990-04-04 | 1990-05-30 | Ace Coin Equip | Amusement apparatus |
US5168441A (en) | 1990-05-30 | 1992-12-01 | Allen-Bradley Company, Inc. | Methods for set up and programming of machine and process controllers |
US5175856A (en) | 1990-06-11 | 1992-12-29 | Supercomputer Systems Limited Partnership | Computer with integrated hierarchical representation (ihr) of program wherein ihr file is available for debugging and optimizing during target execution |
US5390304A (en) | 1990-09-28 | 1995-02-14 | Texas Instruments, Incorporated | Method and apparatus for processing block instructions in a data processor |
US5162986A (en) | 1990-10-19 | 1992-11-10 | Allen-Bradley Company, Inc. | Remote downloading and uploading of motion control program information to and from a motion control I/O module in a programmable controller |
US5412757A (en) | 1990-11-28 | 1995-05-02 | Kabushiki Kaisha Toshiba | Fuzzy control system |
US5175684A (en) | 1990-12-31 | 1992-12-29 | Trans-Link International Corp. | Automatic text translation and routing system |
EP0495147A1 (en) | 1991-01-18 | 1992-07-22 | Siemens Aktiengesellschaft | Method for path correction in numerical controlled machines |
US5120065A (en) | 1991-02-08 | 1992-06-09 | Hasbro, Incorporated | Electronic talking board game |
WO1992015068A1 (en) | 1991-02-15 | 1992-09-03 | Incontrol, Inc. | Computer control system for generating geometric designs |
IL100987A (en) | 1991-02-27 | 1995-10-31 | Digital Equipment Corp | Method and apparatus for compiling code |
IL100989A (en) | 1991-02-27 | 1995-10-31 | Digital Equipment Corp | Analyzing inductive expressions in a multilanguage optimizing compiler |
IL100990A (en) | 1991-02-27 | 1995-10-31 | Digital Equipment Corp | Multilanguage optimizing compiler using templates in multiple pass code generation |
US5659753A (en) | 1991-02-27 | 1997-08-19 | Digital Equipment Corporation | Interface for symbol table construction in a multilanguage optimizing compiler |
US5291416A (en) | 1991-03-08 | 1994-03-01 | Software Algoritms Incorporated | Event feedback for numerically controlled machine tool and network implementation thereof |
FR2675282B1 (en) | 1991-04-12 | 1995-01-20 | Info Telecom | METHOD AND DEVICE FOR MATERIALIZING A VIRTUAL INTERACTION BETWEEN AN OBJECT AND AN INFORMATION MEDIUM. |
US5231693A (en) * | 1991-05-09 | 1993-07-27 | The United States Of America As Represented By The Administrator, National Aeronautics And Space Administration | Telerobot control system |
US5417210A (en) | 1992-05-27 | 1995-05-23 | International Business Machines Corporation | System and method for augmentation of endoscopic surgery |
US5485545A (en) | 1991-06-20 | 1996-01-16 | Mitsubishi Denki Kabushiki Kaisha | Control method using neural networks and a voltage/reactive-power controller for a power system using the control method |
EP0523618B1 (en) | 1991-07-15 | 1997-10-08 | Hitachi, Ltd. | Picture codec and teleconference terminal equipment |
US5625821A (en) * | 1991-08-12 | 1997-04-29 | International Business Machines Corporation | Asynchronous or synchronous operation of event signaller by event management services in a computer system |
CA2075122A1 (en) | 1991-09-23 | 1993-03-24 | He Holdings, Inc. | Multiple participant moving vehicle shooting gallery |
US5889670A (en) * | 1991-10-24 | 1999-03-30 | Immersion Corporation | Method and apparatus for tactilely responsive user interface |
EP0546682A3 (en) | 1991-12-12 | 1993-12-08 | Ibm | Parent class shadowing |
US6400996B1 (en) | 1999-02-01 | 2002-06-04 | Steven M. Hoffberg | Adaptive pattern recognition based control system and method |
US5345538A (en) * | 1992-01-27 | 1994-09-06 | Krishna Narayannan | Voice activated control apparatus |
US5329381A (en) | 1992-02-20 | 1994-07-12 | Payne John H | Automatic engraving method and apparatus |
US5287199A (en) | 1992-02-27 | 1994-02-15 | At&T Bell Laboratories | Facsimile message processing and routing system |
US5400345A (en) | 1992-03-06 | 1995-03-21 | Pitney Bowes Inc. | Communications system to boundary-scan logic interface |
US5917840A (en) | 1992-03-13 | 1999-06-29 | Foxboro Company | Protection against communications crosstalk in a factory process control system |
CA2087503A1 (en) | 1992-04-13 | 1993-10-14 | Lester Wayne Dunaway | Multimodal remote control device having electrically alterable keypad designations |
US5315642A (en) * | 1992-04-16 | 1994-05-24 | Canamex Corporation | Concurrent creation and transmission of text messages to multiple paging services |
US5366376A (en) | 1992-05-22 | 1994-11-22 | Atari Games Corporation | Driver training system and method with performance data feedback |
US5368484A (en) | 1992-05-22 | 1994-11-29 | Atari Games Corp. | Vehicle simulator with realistic operating feedback |
US5541640A (en) | 1992-06-23 | 1996-07-30 | Larson; Craig R. | Videophone for simultaneous audio and video communication via a standard telephone line |
ATE166160T1 (en) | 1992-07-17 | 1998-05-15 | Rxs Schrumpftech Garnituren | ARRANGEMENT FOR PLACING SPLICE CASSETTES FOR OPTICAL FIBERS WITHIN A CABLE SLEEVE |
US5402518A (en) | 1992-07-22 | 1995-03-28 | Pcvoice, Inc. | Sound storage and sound retrieval system having peripheral with hand operable switches |
JP2597802B2 (en) | 1992-08-04 | 1997-04-09 | インターナショナル・ビジネス・マシーンズ・コーポレイション | Method for controlling an image capture device, image capture device and user interface |
ATE190156T1 (en) | 1992-09-04 | 2000-03-15 | Caterpillar Inc | INTEGRATED DESIGN AND TRANSLATION SYSTEM |
JPH06133367A (en) | 1992-09-23 | 1994-05-13 | Walt Disney Co:The | Method and apparatus for remote synchronization of audio, illumination, animation and special effect |
US5574897A (en) | 1992-09-30 | 1996-11-12 | International Business Machines Corporation | System managed logging of objects to speed recovery processing |
AU5363494A (en) | 1992-10-19 | 1994-05-09 | Jeffrey Scott Jani | Video and radio controlled moving and talking device |
US5541838A (en) | 1992-10-26 | 1996-07-30 | Sharp Kabushiki Kaisha | Translation machine having capability of registering idioms |
WO1994010645A1 (en) | 1992-10-28 | 1994-05-11 | Intellution, Inc. | A dynamic graphical system configuration utility |
US5392382A (en) | 1992-12-01 | 1995-02-21 | Schoppers; Marcel J. | Automated plan synthesizer and plan execution method |
US5389865A (en) | 1992-12-02 | 1995-02-14 | Cybernet Systems Corporation | Method and system for providing a tactile virtual reality and manipulator defining an interface device therefor |
US6131097A (en) | 1992-12-02 | 2000-10-10 | Immersion Corporation | Haptic authoring |
US5629594A (en) | 1992-12-02 | 1997-05-13 | Cybernet Systems Corporation | Force feedback system |
EP0606790B1 (en) | 1992-12-08 | 2000-03-22 | Steven Lebensfeld | Toy having subject specific,word/phrase selectable, message delivering doll or action figure |
US5604843A (en) | 1992-12-23 | 1997-02-18 | Microsoft Corporation | Method and system for interfacing with a computer output device |
US5390330A (en) | 1993-02-11 | 1995-02-14 | Talati; Kirit K. | Control system and method for direct execution of software application information models without code generation |
JP2799126B2 (en) | 1993-03-26 | 1998-09-17 | 株式会社ナムコ | Video game device and game input device |
US5666161A (en) | 1993-04-26 | 1997-09-09 | Hitachi, Ltd. | Method and apparatus for creating less amount of compressd image data from compressed still image data and system for transmitting compressed image data through transmission line |
JPH06344279A (en) | 1993-06-07 | 1994-12-20 | Hitachi Ltd | Remote operation device and method |
US5405152A (en) | 1993-06-08 | 1995-04-11 | The Walt Disney Company | Method and apparatus for an interactive video game with physical feedback |
US5731804A (en) | 1995-01-18 | 1998-03-24 | Immersion Human Interface Corp. | Method and apparatus for providing high bandwidth, low noise mechanical I/O for computer systems |
US5734373A (en) | 1993-07-16 | 1998-03-31 | Immersion Human Interface Corporation | Method and apparatus for controlling force feedback interface systems utilizing a host computer |
US6057828A (en) | 1993-07-16 | 2000-05-02 | Immersion Corporation | Method and apparatus for providing force sensations in virtual environments in accordance with host software |
US5739811A (en) | 1993-07-16 | 1998-04-14 | Immersion Human Interface Corporation | Method and apparatus for controlling human-computer interface systems providing force feedback |
WO1995002801A1 (en) * | 1993-07-16 | 1995-01-26 | Immersion Human Interface | Three-dimensional mechanical mouse |
US5392207A (en) | 1993-08-20 | 1995-02-21 | Allen-Bradley Company, Inc. | Programmable motion controller with graphical programming aid |
US5566278A (en) | 1993-08-24 | 1996-10-15 | Taligent, Inc. | Object oriented printing system |
US5377258A (en) | 1993-08-30 | 1994-12-27 | National Medical Research Council | Method and apparatus for an automated and interactive behavioral guidance system |
US5453933A (en) | 1993-09-08 | 1995-09-26 | Hurco Companies, Inc. | CNC control system |
US5413355A (en) | 1993-12-17 | 1995-05-09 | Gonzalez; Carlos | Electronic educational game with responsive animation |
US5566346A (en) | 1993-12-21 | 1996-10-15 | Taligent, Inc. | System for constructing hardware device interface software systems independent of operating systems including capability of installing and removing interrupt handlers |
EP0661885A1 (en) | 1993-12-28 | 1995-07-05 | Canon Kabushiki Kaisha | Image processing method and apparatus for converting between data coded in different formats |
US5511147A (en) | 1994-01-12 | 1996-04-23 | Uti Corporation | Graphical interface for robot |
WO1995019683A1 (en) | 1994-01-14 | 1995-07-20 | Houston Advanced Research Center | Boundary-spline-wavelet compression for video images |
US5438529A (en) | 1994-01-26 | 1995-08-01 | Immersion Human Interface Corporation | Percussion input device for personal computer systems |
CN1106622C (en) | 1994-02-04 | 2003-04-23 | 咨询卡有限公司 | Card creation system and method |
US5485620A (en) | 1994-02-25 | 1996-01-16 | Automation System And Products, Inc. | Integrated control system for industrial automation applications |
JPH07262025A (en) | 1994-03-18 | 1995-10-13 | Fujitsu Ltd | Execution control system |
WO1995025991A1 (en) * | 1994-03-23 | 1995-09-28 | Kabushiki Kaisha Yaskawa Denki | Machine controller |
GB2289186A (en) | 1994-04-05 | 1995-11-08 | Ibm | Collaborative working method and system |
US5754855A (en) * | 1994-04-21 | 1998-05-19 | International Business Machines Corporation | System and method for managing control flow of computer programs executing in a computer system |
US6471420B1 (en) * | 1994-05-13 | 2002-10-29 | Matsushita Electric Industrial Co., Ltd. | Voice selection apparatus voice response apparatus, and game apparatus using word tables from which selected words are output as voice selections |
US5465215A (en) | 1994-07-07 | 1995-11-07 | Cincinnati Milacron Inc. | Numerical control method and apparatus |
US5623582A (en) | 1994-07-14 | 1997-04-22 | Immersion Human Interface Corporation | Computer interface or control input device for laparoscopic surgical instrument and other elongated mechanical objects |
US5821920A (en) | 1994-07-14 | 1998-10-13 | Immersion Human Interface Corporation | Control input device for interfacing an elongated flexible object with a computer system |
US5733131A (en) | 1994-07-29 | 1998-03-31 | Seiko Communications Holding N.V. | Education and entertainment device with dynamic configuration and operation |
US5692195A (en) | 1994-08-31 | 1997-11-25 | International Business Machines Corporation | Parent class shadowing |
AU3412295A (en) | 1994-09-01 | 1996-03-22 | Gary L. Mcalpine | A multi-port memory system including read and write buffer interfaces |
US5881213A (en) | 1994-10-05 | 1999-03-09 | Microsoft Corporation | Deferred printing |
JP3325134B2 (en) | 1994-10-21 | 2002-09-17 | パイオニア株式会社 | Video game system |
WO1996015837A1 (en) * | 1994-11-21 | 1996-05-30 | Compaq Computer Corporation | Interactive play with a computer |
US5831606A (en) | 1994-12-13 | 1998-11-03 | Microsoft Corporation | Shell extensions for an operating system |
US5724074A (en) | 1995-02-06 | 1998-03-03 | Microsoft Corporation | Method and system for graphically programming mobile toys |
JP3254994B2 (en) * | 1995-03-01 | 2002-02-12 | セイコーエプソン株式会社 | Speech recognition dialogue apparatus and speech recognition dialogue processing method |
US5680619A (en) | 1995-04-03 | 1997-10-21 | Mfactory, Inc. | Hierarchical encapsulation of instantiated objects in a multimedia authoring system |
US5748468A (en) * | 1995-05-04 | 1998-05-05 | Microsoft Corporation | Prioritized co-processor resource manager and method |
US5802365A (en) | 1995-05-05 | 1998-09-01 | Apple Computer, Inc. | Dynamic device matching using driver candidate lists |
GB2300991B (en) | 1995-05-15 | 1997-11-05 | Andrew Macgregor Ritchie | Serving signals to browsing clients |
JP3091135B2 (en) | 1995-05-26 | 2000-09-25 | 株式会社バンダイ | Game equipment |
CA2586401C (en) | 1995-05-30 | 2010-07-13 | Roy-G-Biv Corporation | Motion control systems |
US6941543B1 (en) | 1995-05-30 | 2005-09-06 | Roy-G-Biv Corporation | Motion control system and method |
US6571141B1 (en) * | 1995-05-30 | 2003-05-27 | Roy-G-Biv Corporation | Application programs for motion control devices including access limitations |
US20020156872A1 (en) | 2001-01-04 | 2002-10-24 | Brown David W. | Systems and methods for transmitting motion control data |
US20060206219A1 (en) | 1995-05-30 | 2006-09-14 | Brown David W | Motion control systems and methods |
US6859671B1 (en) * | 1995-05-30 | 2005-02-22 | Roy-G-Biv Corporation | Application programs for motion control devices including access limitations |
US7035697B1 (en) * | 1995-05-30 | 2006-04-25 | Roy-G-Biv Corporation | Access control systems and methods for motion control |
US5691898A (en) | 1995-09-27 | 1997-11-25 | Immersion Human Interface Corp. | Safe and low cost computer peripherals with force feedback for consumer applications |
US5761669A (en) * | 1995-06-06 | 1998-06-02 | Microsoft Corporation | Controlling access to objects on multiple operating systems |
US6166723A (en) | 1995-11-17 | 2000-12-26 | Immersion Corporation | Mouse interface device providing force feedback |
JP3968133B2 (en) * | 1995-06-22 | 2007-08-29 | セイコーエプソン株式会社 | Speech recognition dialogue processing method and speech recognition dialogue apparatus |
US5842168A (en) * | 1995-08-21 | 1998-11-24 | Seiko Epson Corporation | Cartridge-based, interactive speech recognition device with response-creation capability |
JP3697748B2 (en) * | 1995-08-21 | 2005-09-21 | セイコーエプソン株式会社 | Terminal, voice recognition device |
JP3674990B2 (en) * | 1995-08-21 | 2005-07-27 | セイコーエプソン株式会社 | Speech recognition dialogue apparatus and speech recognition dialogue processing method |
TW273519B (en) | 1995-09-12 | 1996-04-01 | Konami Co Ltd | Driving game machine |
US5959613A (en) | 1995-12-01 | 1999-09-28 | Immersion Corporation | Method and apparatus for shaping force signals for a force feedback device |
US5801946A (en) | 1995-10-19 | 1998-09-01 | Kawasaki Motors Mfg. Co. | Assembly prompting system |
US5800268A (en) | 1995-10-20 | 1998-09-01 | Molnick; Melvin | Method of participating in a live casino game from a remote location |
US5898588A (en) * | 1995-10-27 | 1999-04-27 | Dainippon Screen Mfg. Co. | Method and apparatus for controlling substrate processing apparatus |
US5636994A (en) | 1995-11-09 | 1997-06-10 | Tong; Vincent M. K. | Interactive computer controlled doll |
US5825308A (en) | 1996-11-26 | 1998-10-20 | Immersion Human Interface Corporation | Force feedback interface having isotonic and isometric functionality |
US6100874A (en) * | 1995-11-17 | 2000-08-08 | Immersion Corporation | Force feedback mouse interface |
US5752880A (en) | 1995-11-20 | 1998-05-19 | Creator Ltd. | Interactive doll |
US6061004A (en) | 1995-11-26 | 2000-05-09 | Immersion Corporation | Providing force feedback using an interface device including an indexing function |
US6169540B1 (en) * | 1995-12-01 | 2001-01-02 | Immersion Corporation | Method and apparatus for designing force sensations in force feedback applications |
US6028593A (en) * | 1995-12-01 | 2000-02-22 | Immersion Corporation | Method and apparatus for providing simulated physical interactions within computer generated environments |
US6219032B1 (en) * | 1995-12-01 | 2001-04-17 | Immersion Corporation | Method for providing force feedback to a user of an interface device based on interactions of a controlled cursor with graphical elements in a graphical user interface |
US5956484A (en) | 1995-12-13 | 1999-09-21 | Immersion Corporation | Method and apparatus for providing force feedback over a computer network |
US6078308A (en) | 1995-12-13 | 2000-06-20 | Immersion Corporation | Graphical click surfaces for force feedback applications to provide user selection using cursor interaction with a trigger position within a boundary of a graphical object |
US6161126A (en) | 1995-12-13 | 2000-12-12 | Immersion Corporation | Implementing force feedback over the World Wide Web and other computer networks |
US6300936B1 (en) | 1997-11-14 | 2001-10-09 | Immersion Corporation | Force feedback system including multi-tasking graphical host environment and interface device |
JP3120963B2 (en) | 1995-12-14 | 2000-12-25 | 株式会社日立製作所 | Method for transferring messages and system for transferring messages |
US6305011B1 (en) | 1996-01-16 | 2001-10-16 | Sun Microsystems, Inc. | Tip technology and its application to sparcompiler pascal |
US6553410B2 (en) | 1996-02-27 | 2003-04-22 | Inpro Licensing Sarl | Tailoring data and transmission protocol for efficient interactive data transactions over wide-area networks |
US5746602A (en) | 1996-02-27 | 1998-05-05 | Kikinis; Dan | PC peripheral interactive doll |
US5805785A (en) * | 1996-02-27 | 1998-09-08 | International Business Machines Corporation | Method for monitoring and recovery of subsystems in a distributed/clustered system |
US5737523A (en) | 1996-03-04 | 1998-04-07 | Sun Microsystems, Inc. | Methods and apparatus for providing dynamic network file system client authentication |
US5764155A (en) | 1996-04-03 | 1998-06-09 | General Electric Company | Dynamic data exchange server |
WO1997041936A1 (en) * | 1996-04-05 | 1997-11-13 | Maa Shalong | Computer-controlled talking figure toy with animated features |
US5846132A (en) | 1996-04-10 | 1998-12-08 | William W. Junkin Trust | Interactive system allowing simulated or real time participation in a league |
US5822207A (en) | 1996-05-06 | 1998-10-13 | Amadasoft America, Inc. | Apparatus and method for integrating intelligent manufacturing system with expert sheet metal planning and bending system |
US5828575A (en) | 1996-05-06 | 1998-10-27 | Amadasoft America, Inc. | Apparatus and method for managing and distributing design and manufacturing information throughout a sheet metal production facility |
US5666264A (en) | 1996-05-13 | 1997-09-09 | Nematron Corporation | Industrial computer workstation |
US6374255B1 (en) * | 1996-05-21 | 2002-04-16 | Immersion Corporation | Haptic authoring |
US5805442A (en) | 1996-05-30 | 1998-09-08 | Control Technology Corporation | Distributed interface architecture for programmable industrial control systems |
US5921780A (en) | 1996-06-28 | 1999-07-13 | Myers; Nicole J. | Racecar simulator and driver training system and method |
JP3832517B2 (en) * | 1996-07-05 | 2006-10-11 | セイコーエプソン株式会社 | Robot controller and control method thereof |
US6125385A (en) | 1996-08-01 | 2000-09-26 | Immersion Corporation | Force feedback implementation in web pages |
US5832189A (en) | 1996-09-26 | 1998-11-03 | Interval Research Corporation | Affect-based robot communication methods and systems |
US5890963A (en) * | 1996-09-30 | 1999-04-06 | Yen; Wei | System and method for maintaining continuous and progressive game play in a computer network |
US5920476A (en) | 1996-11-21 | 1999-07-06 | Hennessey; John M. | Computer controlled movement of stage effects and stage installation employing same |
US6128006A (en) | 1998-03-26 | 2000-10-03 | Immersion Corporation | Force feedback mouse wheel and other control wheels |
US6139177A (en) | 1996-12-03 | 2000-10-31 | Hewlett Packard Company | Device access and control using embedded web access functionality |
US6523119B2 (en) | 1996-12-04 | 2003-02-18 | Rainbow Technologies, Inc. | Software protection device and method |
US6075843A (en) * | 1996-12-05 | 2000-06-13 | Intervoice Limited Partnership | User device-independent transaction model |
US5848415A (en) | 1996-12-18 | 1998-12-08 | Unisys Corporation | Selective multiple protocol transport and dynamic format conversion in a multi-user network |
US6080063A (en) | 1997-01-06 | 2000-06-27 | Khosla; Vinod | Simulated real time game play with live event |
US5873765A (en) * | 1997-01-07 | 1999-02-23 | Mattel, Inc. | Toy having data downloading station |
US5977951A (en) | 1997-02-04 | 1999-11-02 | Microsoft Corporation | System and method for substituting an animated character when a remote control physical character is unavailable |
US5942869A (en) | 1997-02-13 | 1999-08-24 | Honda Giken Kogyo Kabushiki Kaisha | Mobile robot control device |
US6038603A (en) * | 1997-03-25 | 2000-03-14 | Oracle Corporation | Processing customized uniform resource locators |
US5960085A (en) | 1997-04-14 | 1999-09-28 | De La Huerga; Carlos | Security badge for automated access control and secure data gathering |
US5907831A (en) | 1997-04-04 | 1999-05-25 | Lotvin; Mikhail | Computer apparatus and methods supporting different categories of users |
CA2225060A1 (en) | 1997-04-09 | 1998-10-09 | Peter Suilun Fong | Interactive talking dolls |
US6020876A (en) * | 1997-04-14 | 2000-02-01 | Immersion Corporation | Force feedback interface with selective disturbance filter |
US6285351B1 (en) | 1997-04-25 | 2001-09-04 | Immersion Corporation | Designing force sensations for computer applications including sounds |
US6292170B1 (en) | 1997-04-25 | 2001-09-18 | Immersion Corporation | Designing compound force sensations for computer applications |
US6233545B1 (en) | 1997-05-01 | 2001-05-15 | William E. Datig | Universal machine translator of arbitrary languages utilizing epistemic moments |
US6065365A (en) | 1997-05-08 | 2000-05-23 | Case Corporation | Control lever assembly |
US6012961A (en) * | 1997-05-14 | 2000-01-11 | Design Lab, Llc | Electronic toy including a reprogrammable data storage device |
CA2205797C (en) | 1997-05-22 | 2001-04-24 | Andrew Wilfred Macleod | A system for local context spilling for graph colouring register allocators |
US6243707B1 (en) | 1997-06-25 | 2001-06-05 | Samsung Electronics Co. Ltd. | Method and apparatus for creating home network macros |
JP3167963B2 (en) | 1997-07-07 | 2001-05-21 | コナミ株式会社 | Manual operation device and game device |
US6425118B1 (en) | 1997-07-18 | 2002-07-23 | Compaq Computer Corporation | System for automatically generating tests to ensure binary compatibility between software components produced by a source-to-source computer language translator |
US6317871B1 (en) | 1997-07-18 | 2001-11-13 | Compaq Computer Corporation | System for ensuring the accuracy of file structures in a source-to-source computer program translator |
JP3352611B2 (en) | 1997-07-24 | 2002-12-03 | 株式会社日立製作所 | Switching router |
CA2211515C (en) | 1997-07-25 | 2001-12-11 | Kevin Alexander Stoodley | System and method of local data alignment for stack memory |
GB2327786B (en) | 1997-07-31 | 2002-04-03 | Ibm | Method and apparatus for strategic compilation of source programs into two or more target languages |
US6463404B1 (en) | 1997-08-08 | 2002-10-08 | British Telecommunications Public Limited Company | Translation |
US6252579B1 (en) | 1997-08-23 | 2001-06-26 | Immersion Corporation | Interface device and method for providing enhanced cursor control with force feedback |
US6292174B1 (en) | 1997-08-23 | 2001-09-18 | Immersion Corporation | Enhanced cursor control using limited-workspace force feedback devices |
IL121642A0 (en) | 1997-08-27 | 1998-02-08 | Creator Ltd | Interactive talking toy |
US5924013A (en) | 1997-09-03 | 1999-07-13 | Guido; Mary M. | Method and apparatus for transmitting motion picture cinematic information for viewing in movie theaters and ordering method therefor |
US5984499A (en) | 1997-09-12 | 1999-11-16 | Manufacturing Data Systems, Inc. | Method and apparatus for a numerical control system for processing multiple job streams |
US6078968A (en) | 1997-10-03 | 2000-06-20 | Vicom Systems, Inc. | Platform-independent communications protocol supporting communications between a processor and subsystem controller based on identifying information |
US20010032278A1 (en) | 1997-10-07 | 2001-10-18 | Brown Stephen J. | Remote generation and distribution of command programs for programmable devices |
KR100250977B1 (en) | 1997-10-16 | 2000-04-15 | 이계철 | High speed packet switch controller using neural chip and exchanger using the controller |
US5991528A (en) | 1997-11-05 | 1999-11-23 | Reliance Electric Industrial Company | Expert manufacturing system |
US6252583B1 (en) * | 1997-11-14 | 2001-06-26 | Immersion Corporation | Memory and force output management for a force feedback system |
US6243078B1 (en) | 1998-06-23 | 2001-06-05 | Immersion Corporation | Pointing device with forced feedback button |
US6055579A (en) | 1997-11-17 | 2000-04-25 | Silicon Graphics, Inc. | Distributed control and synchronization of multiple data processors using flexible command queues |
US6101425A (en) | 1997-11-26 | 2000-08-08 | Allen-Bradley Company, Llc | Multiple connection networked man-machine interfaces for computer numerical controls |
US6144895A (en) | 1997-11-26 | 2000-11-07 | Allen-Bradley Company, Llc | System and method for networking a computer numerical control with a workstation |
JP3437426B2 (en) | 1997-11-28 | 2003-08-18 | パイオニア株式会社 | Information recording medium, information reproducing apparatus and information reproducing method |
US6470377B1 (en) | 1997-12-19 | 2002-10-22 | Rockwell Automation Technologies, Inc. | Networked file operations for computer numerical controls |
US6133867A (en) | 1998-01-02 | 2000-10-17 | Eberwine; David Brent | Integrated air traffic management and collision avoidance system |
US6078747A (en) | 1998-01-05 | 2000-06-20 | Jewitt; James W. | Application program interface to physical devices |
US6083104A (en) | 1998-01-16 | 2000-07-04 | Silverlit Toys (U.S.A.), Inc. | Programmable toy with an independent game cartridge |
US6216173B1 (en) * | 1998-02-03 | 2001-04-10 | Redbox Technologies Limited | Method and apparatus for content processing and routing |
US6304091B1 (en) | 1998-02-10 | 2001-10-16 | Immersion Corporation | Absolute position sensing by phase shift detection using a variable capacitor |
US6247994B1 (en) | 1998-02-11 | 2001-06-19 | Rokenbok Toy Company | System and method for communicating with and controlling toy accessories |
US6208640B1 (en) | 1998-02-27 | 2001-03-27 | David Spell | Predictive bandwidth allocation method and apparatus |
US6560592B1 (en) | 1998-03-19 | 2003-05-06 | Micro Data Base Systems, Inc. | Multi-model computer database storage system with integrated rule engine |
US6173316B1 (en) * | 1998-04-08 | 2001-01-09 | Geoworks Corporation | Wireless communication device with markup language based man-machine interface |
US6678713B1 (en) * | 1998-04-29 | 2004-01-13 | Xerox Corporation | Machine control using a schedulerlock construct |
US6201996B1 (en) * | 1998-05-29 | 2001-03-13 | Control Technology Corporationa | Object-oriented programmable industrial controller with distributed interface architecture |
AU4690899A (en) | 1998-06-18 | 2000-01-05 | Kline & Walker Llc | Automated devices to control equipment and machines with remote control and accountability worldwide |
US6615091B1 (en) | 1998-06-26 | 2003-09-02 | Eveready Battery Company, Inc. | Control system and method therefor |
JP4257553B2 (en) | 1998-07-07 | 2009-04-22 | 株式会社安川電機 | Motion controller program creation and execution method |
US8098140B1 (en) * | 2000-07-13 | 2012-01-17 | Universal Electronics Inc. | Customizable and upgradable devices and methods related thereto |
US6519646B1 (en) * | 1998-09-01 | 2003-02-11 | Sun Microsystems, Inc. | Method and apparatus for encoding content characteristics |
US6242880B1 (en) | 1998-09-08 | 2001-06-05 | Cimplus, Inc. | Tolerance based motion control system |
US6147647A (en) | 1998-09-09 | 2000-11-14 | Qualcomm Incorporated | Circularly polarized dielectric resonator antenna |
US6559860B1 (en) | 1998-09-29 | 2003-05-06 | Rockwell Software Inc. | Method and apparatus for joining and manipulating graphical objects in a graphical user interface |
US6366293B1 (en) * | 1998-09-29 | 2002-04-02 | Rockwell Software Inc. | Method and apparatus for manipulating and displaying graphical objects in a computer display device |
US6473824B1 (en) | 1998-10-14 | 2002-10-29 | International Business Machines Corporation | Dynamic association of input/output device with application programs |
US6519594B1 (en) * | 1998-11-14 | 2003-02-11 | Sony Electronics, Inc. | Computer-implemented sharing of java classes for increased memory efficiency and communication method |
JP3788697B2 (en) * | 1998-11-18 | 2006-06-21 | 富士通株式会社 | Message control unit |
US6345212B1 (en) * | 1998-11-20 | 2002-02-05 | Manufacturing Data Systems, Inc. | Automatic variable linkage mechanism for integrating third party software components |
JP3980205B2 (en) | 1998-12-17 | 2007-09-26 | コニカミノルタホールディングス株式会社 | Work robot |
US6665688B1 (en) | 1998-12-23 | 2003-12-16 | Cray Inc. | Method and system for automatically regenerating data on-demand |
US6523171B1 (en) * | 1998-12-29 | 2003-02-18 | International Business Machines Corporation | Enhanced source code translator from procedural programming language (PPL) to an object oriented programming language (OOPL) |
JP3424631B2 (en) | 1999-01-13 | 2003-07-07 | ソニー株式会社 | Robot apparatus and software updating method |
JP3748726B2 (en) * | 1999-01-28 | 2006-02-22 | シャープ株式会社 | Quantum wire manufacturing method |
US6546436B1 (en) * | 1999-03-30 | 2003-04-08 | Moshe Fainmesser | System and interface for controlling programmable toys |
US6944584B1 (en) | 1999-04-16 | 2005-09-13 | Brooks Automation, Inc. | System and method for control and simulation |
US6850806B2 (en) * | 1999-04-16 | 2005-02-01 | Siemens Energy & Automation, Inc. | Method and apparatus for determining calibration options in a motion control system |
JP2000311008A (en) | 1999-04-28 | 2000-11-07 | Yaskawa Electric Corp | Programming method for motion controller |
US6788980B1 (en) * | 1999-06-11 | 2004-09-07 | Invensys Systems, Inc. | Methods and apparatus for control using control devices that provide a virtual machine environment and that communicate via an IP network |
US6625661B1 (en) * | 1999-06-21 | 2003-09-23 | Kenneth G. Baldwin, Jr. | Interactive entertainment system |
US6374195B1 (en) * | 1999-06-29 | 2002-04-16 | Daimlerchrysler Corporation | System for monitoring and tracking tool and tool performance |
US6290565B1 (en) | 1999-07-21 | 2001-09-18 | Nearlife, Inc. | Interactive game apparatus with game play controlled by user-modifiable toy |
US6401005B1 (en) | 1999-09-27 | 2002-06-04 | Rockwell Automation Technologies, Inc. | Programmable synchronous and asynchronous block execution for a computer numerical control |
US6606665B2 (en) | 1999-09-27 | 2003-08-12 | Rockwell Automation Technologies, Inc. | Multiple connection architecture for communication with a computer numerical control resident in a workstation and other networked computer numerical controls |
US6778949B2 (en) | 1999-10-18 | 2004-08-17 | Sony Corporation | Method and system to analyze, transfer and generate language expressions using compiled instructions to manipulate linguistic structures |
US8032605B2 (en) * | 1999-10-27 | 2011-10-04 | Roy-G-Biv Corporation | Generation and distribution of motion commands over a distributed network |
US6879862B2 (en) | 2000-02-28 | 2005-04-12 | Roy-G-Biv Corporation | Selection and control of motion data |
US6560513B2 (en) | 1999-11-19 | 2003-05-06 | Fanuc Robotics North America | Robotic system with teach pendant |
US6518980B1 (en) * | 1999-11-19 | 2003-02-11 | Fanuc Robotics North America, Inc. | Method and system for allowing a programmable controller to communicate with a remote computer |
US6662361B1 (en) | 2000-01-14 | 2003-12-09 | International Business Machines Corporation | Method, system, program, and data structures for transforming an instruction in a first bit architecture to an instruction in a second bit architecture |
US20020045956A1 (en) | 2000-02-18 | 2002-04-18 | Kapitan Brian A. | Network distributed motion control system |
GB0006292D0 (en) | 2000-03-15 | 2000-05-03 | Pathfinder Tech Resources Ltd | Telephone call dialling |
JP3333773B2 (en) | 2000-04-14 | 2002-10-15 | コナミ株式会社 | GAME DEVICE, GAME DEVICE CONTROL METHOD, AND INFORMATION STORAGE MEDIUM |
JP2001353678A (en) | 2000-06-12 | 2001-12-25 | Sony Corp | Authoring system and method and storage medium |
US7000191B2 (en) | 2000-08-07 | 2006-02-14 | Siemens Aktiengesellschaft | Flowchart programming for industrial controllers, in particular motion controllers |
US7216179B2 (en) | 2000-08-16 | 2007-05-08 | Semandex Networks Inc. | High-performance addressing and routing of data packets with semantically descriptive labels in a computer network |
US7366769B2 (en) | 2000-10-02 | 2008-04-29 | Schlumberger Technology Corporation | System, method and computer program product for a universal communication connector |
JP2002127059A (en) | 2000-10-20 | 2002-05-08 | Sony Corp | Action control device and method, pet robot and control method, robot control system and recording medium |
US6439956B1 (en) | 2000-11-13 | 2002-08-27 | Interact Accessories, Inc. | RC car device |
DE10058524A1 (en) | 2000-11-24 | 2002-06-13 | Siemens Ag | System and method for the parallel transmission of real-time-critical and non-real-time-critical data via switchable data networks, in particular Ethernet |
KR100362611B1 (en) * | 2000-12-13 | 2002-11-29 | 삼성전자 주식회사 | Robot and Motor Speed Control Method Thereof |
US6442451B1 (en) * | 2000-12-28 | 2002-08-27 | Robotic Workspace Technologies, Inc. | Versatile robot control system |
US6658325B2 (en) | 2001-01-16 | 2003-12-02 | Stephen Eliot Zweig | Mobile robotic with web server and digital radio links |
US6733293B2 (en) * | 2001-01-26 | 2004-05-11 | Provision Entertainment, Inc. | Personal simulator |
US7137891B2 (en) | 2001-01-31 | 2006-11-21 | Sony Computer Entertainment America Inc. | Game playing system with assignable attack icons |
US7904194B2 (en) * | 2001-02-09 | 2011-03-08 | Roy-G-Biv Corporation | Event management systems and methods for motion control systems |
US6491566B2 (en) * | 2001-03-26 | 2002-12-10 | Intel Corporation | Sets of toy robots adapted to act in concert, software and methods of playing with the same |
US6907029B2 (en) * | 2001-03-29 | 2005-06-14 | Tord Brabrand | Remote control system |
US6859747B2 (en) * | 2001-04-26 | 2005-02-22 | Siemens Energy & Automation, Inc. | Method and apparatus for self-calibrating a motion control system |
US6865499B2 (en) | 2001-04-26 | 2005-03-08 | Siemens Energy & Automation, Inc. | Method and apparatus for tuning compensation parameters in a motion control system associated with a mechanical member |
US6652378B2 (en) | 2001-06-01 | 2003-11-25 | Igt | Gaming machines and systems offering simultaneous play of multiple games and methods of gaming |
US6845276B2 (en) * | 2001-06-29 | 2005-01-18 | Electro Scientific Industries | Multiple axis modular controller and method of operating same |
US6922826B2 (en) | 2001-07-03 | 2005-07-26 | International Business Machines Corporation | Debugger impact reduction through breakpoint motion |
US7194412B2 (en) * | 2001-07-19 | 2007-03-20 | Overhead Door Corporation | Speech activated door operator system |
US7367028B2 (en) * | 2001-08-14 | 2008-04-29 | National Instruments Corporation | Graphically deploying programs on devices in a system |
US7165005B2 (en) | 2001-08-14 | 2007-01-16 | National Instruments Corporation | Measurement module interface protocol database and registration system |
US6965816B2 (en) | 2001-10-01 | 2005-11-15 | Kline & Walker, Llc | PFN/TRAC system FAA upgrades for accountable remote and robotics control to stop the unauthorized use of aircraft and to improve equipment management and public safety in transportation |
WO2003045639A2 (en) | 2001-11-28 | 2003-06-05 | Evolution Robotics, Inc. | Sensor and actuator abstraction and aggregation in a hardware abstraction layer for a robot |
US6684157B2 (en) | 2001-12-06 | 2004-01-27 | Yazaki North America, Inc. | Method and system for interfacing a global positioning system, other navigational equipment and wireless networks with a digital data network |
US7117105B2 (en) | 2002-02-25 | 2006-10-03 | General Electric Company | Method and apparatus for ground fault protection |
US7505889B2 (en) * | 2002-02-25 | 2009-03-17 | Zoran Corporation | Transcoding media system |
US6925357B2 (en) | 2002-07-25 | 2005-08-02 | Intouch Health, Inc. | Medical tele-robotic system |
ES2650409T3 (en) * | 2003-05-14 | 2018-01-18 | D-Box Technologies Inc. | Flexible interface to control a movement platform |
US7558320B2 (en) * | 2003-06-13 | 2009-07-07 | Microsoft Corporation | Quality control in frame interpolation with motion analysis |
US20060064503A1 (en) | 2003-09-25 | 2006-03-23 | Brown David W | Data routing systems and methods |
US8027349B2 (en) | 2003-09-25 | 2011-09-27 | Roy-G-Biv Corporation | Database event driven motion systems |
US20070022194A1 (en) | 2003-09-25 | 2007-01-25 | Brown David W | Database event driven motion systems |
EP1690173A4 (en) | 2003-11-17 | 2010-04-21 | Roy G Biv Corp | Command processing systems and methods |
US20050255916A1 (en) * | 2004-05-12 | 2005-11-17 | Paul Chen | Adaptable game controller |
US7395082B2 (en) * | 2004-06-23 | 2008-07-01 | Broadcom Corporation | Method and system for handling events in an application framework for a wireless device |
US7617501B2 (en) | 2004-07-09 | 2009-11-10 | Quest Software, Inc. | Apparatus, system, and method for managing policies on a computer having a foreign operating system |
EP1834230A1 (en) * | 2004-12-30 | 2007-09-19 | Samsung Electronics Co., Ltd. | A terminal data format and a communication control system and method using the terminal data format |
-
2007
- 2007-03-26 US US11/728,801 patent/US7904194B2/en not_active Expired - Fee Related
-
2010
- 2010-10-01 US US12/896,750 patent/US20110071652A1/en not_active Abandoned
-
2012
- 2012-12-18 US US13/719,112 patent/US20130110259A1/en not_active Abandoned
-
2014
- 2014-12-16 US US14/572,611 patent/US20150105869A1/en not_active Abandoned
Patent Citations (21)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5691897A (en) * | 1995-05-30 | 1997-11-25 | Roy-G-Biv Corporation | Motion control systems |
US5867385A (en) * | 1995-05-30 | 1999-02-02 | Roy-G-Biv Corporation | Motion control systems |
US6513058B2 (en) * | 1995-05-30 | 2003-01-28 | Roy-G-Biv Corporation | Distribution of motion control commands over a network |
US6542925B2 (en) * | 1995-05-30 | 2003-04-01 | Roy-G-Biv Corporation | Generation and distribution of motion commands over a distributed network |
US7139843B1 (en) * | 1995-05-30 | 2006-11-21 | Roy-G-Biv Corporation | System and methods for generating and communicating motion data through a distributed network |
US6292712B1 (en) * | 1998-01-29 | 2001-09-18 | Northrop Grumman Corporation | Computer interface system for a robotic system |
US6529802B1 (en) * | 1998-06-23 | 2003-03-04 | Sony Corporation | Robot and information processing system |
US6480896B1 (en) * | 1999-10-27 | 2002-11-12 | Roy-G-Biv Corporation | Systems and methods for generating and communicating motion data through a distributed network |
US20100131080A1 (en) * | 1999-10-27 | 2010-05-27 | Roy-G-Biv Corporation | Event Driven Motion Systems |
US6522951B2 (en) * | 1999-12-09 | 2003-02-18 | Kuka Roboter Gmbh | Method and device for controlling a robot |
US6292714B1 (en) * | 2000-05-12 | 2001-09-18 | Fujitsu Limited | Robot cooperation device, and robot cooperation program storage medium |
US20020103575A1 (en) * | 2001-01-30 | 2002-08-01 | Tomoyoshi Sugawara | Program executing method, system and program processing unit for robot |
US7031798B2 (en) * | 2001-02-09 | 2006-04-18 | Roy-G-Biv Corporation | Event management systems and methods for the distribution of motion control commands |
US7024255B1 (en) * | 2001-05-18 | 2006-04-04 | Roy-G-Biv Corporation | Event driven motion systems |
US6885898B1 (en) * | 2001-05-18 | 2005-04-26 | Roy-G-Biv Corporation | Event driven motion systems |
US7139642B2 (en) * | 2001-11-07 | 2006-11-21 | Sony Corporation | Robot system and robot apparatus control method |
US7024666B1 (en) * | 2002-01-28 | 2006-04-04 | Roy-G-Biv Corporation | Motion control systems and methods |
US20040093219A1 (en) * | 2002-11-13 | 2004-05-13 | Ho-Chul Shin | Home robot using home server, and home network system having the same |
US20040098167A1 (en) * | 2002-11-18 | 2004-05-20 | Sang-Kug Yi | Home robot using supercomputer, and home network system having the same |
US7137107B1 (en) * | 2003-04-29 | 2006-11-14 | Roy-G-Biv Corporation | Motion control systems and methods |
US7949616B2 (en) * | 2004-06-01 | 2011-05-24 | George Samuel Levy | Telepresence by human-assisted remote controlled devices and robots |
Cited By (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US9915934B2 (en) | 1999-05-04 | 2018-03-13 | Automation Middleware Solutions, Inc. | Systems and methods for communicating with motion control systems and devices |
US9588510B2 (en) | 2003-09-25 | 2017-03-07 | Automation Middleware Solutions, Inc. | Database event driven motion systems |
TWI709833B (en) * | 2018-09-20 | 2020-11-11 | 日商斯庫林集團股份有限公司 | Data processing method, data processing device, and computer-readable recording medium |
US11474150B2 (en) | 2018-09-20 | 2022-10-18 | SCREEN Holdings Co., Ltd. | Data processing method, data processing device, and non-transitory computer-readable recording medium |
Also Published As
Publication number | Publication date |
---|---|
US7904194B2 (en) | 2011-03-08 |
US20150105869A1 (en) | 2015-04-16 |
US20110071652A1 (en) | 2011-03-24 |
US20100131079A1 (en) | 2010-05-27 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US7904194B2 (en) | Event management systems and methods for motion control systems | |
US7031798B2 (en) | Event management systems and methods for the distribution of motion control commands | |
US6675193B1 (en) | Method and system for remote control of a local system | |
EP1276026B1 (en) | Object oriented Internet interface for industrial controller | |
US6370436B1 (en) | Distributed objects for a computer system | |
KR100399268B1 (en) | Systems that transfer built-in applications from the network | |
Becker et al. | Base-a micro-broker-based middleware for pervasive computing | |
US6275868B1 (en) | Script Engine interface for multiple languages | |
US7137107B1 (en) | Motion control systems and methods | |
WO2016151398A1 (en) | System and method for configuring a platform instance at runtime | |
US20070022194A1 (en) | Database event driven motion systems | |
AU5184301A (en) | Human machine interface | |
WO2001073550A2 (en) | System and method of generating and using proxy beans | |
US20050132104A1 (en) | Command processing systems and methods | |
JP2002532776A (en) | System and method for configuring an OLE process control compliant data server from a non-compliant user application | |
AU2006201207B2 (en) | Human machine interface | |
Kelly et al. | TCP Connections | |
WO2016193816A1 (en) | System and method for providing persistence in a configurable platform instance | |
JP4342545B2 (en) | Information processing method and information processing system | |
Heintz | Enabling OpenWindow for use with enterprise firewalls |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
AS | Assignment |
Owner name: ROY-G-BIV CORPORATION, WASHINGTON Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:BROWN, DAVID W.;STEIN, SKYLAR;REEL/FRAME:030273/0415 Effective date: 20130305 |
|
STCB | Information on status: application discontinuation |
Free format text: ABANDONED -- FAILURE TO RESPOND TO AN OFFICE ACTION |