Graphical user interface for easily configuring measurement applications
System and method for using a graphical user interface (GUI) to generate a measurement task specification (MTS) for performing a measurement task. The measurement task includes measurement and/or signal generation. A measurement task specifier presents a GUI which guides a user in specifying the measurement task. The GUI presents a plurality of GUI elements, e.g., panels, for specifying a plurality of parameters for the measurement task, including measurement type, devices, channels, timing, and/or triggering. The GUI receives user input indicating values for the parameters, and may provide default values for at least some of the parameters. The GUI stores the parameter values in a memory, analyzes the parameter values, and generates the MTS in response to the analyzing. The MTS is then useable to produce a program which implements the measurement task. The specifier may programmatically generate the program, e.g., a graphical program, which is executable to perform the task.
Latest National Instruments Corporation Patents:
- System and method for efficient data movement in an orchestrated distributed measurement application
- LLC power supply current-sharing and frequency locking mechanism
- Modular card cage accessories
- Reduction of emulated channel count for phased-array systems through angle-of-arrival processing
- Direct network access by a memory mapped peripheral device for scheduled data transfer on the network
This application is a Continuation of U.S. application Ser. No. 10/128,843 titled “Measurement System Graphical User Interface for Easily Configuring Measurement Applications” filed Apr. 24, 2002, whose inventors are Brian Johnson, John Breyer, and Joseph Albert Savage, which is hereby incorporated by reference as though fully and completely set forth herein, and which has issued as U.S. Pat. No. 7,162,387, which is a Continuation-in-Part of U.S. application Ser. No. 10/008,792 titled “Measurement System Software Architecture for Easily Creating High-Performance Measurement Applications” filed Nov. 13, 2001, whose inventors are Geoffrey Schmit, Brent Schwan, Jonathan Brumley, Thomas A. Makowski, and Christopher T. Bartz, and which issued as U.S. Pat. No. 6,879,926, which claims benefit of priority of U.S. provisional application Ser. No. 60/301,785 titled “Measurement System Software Architecture for Easily Creating High-Performance Measurement Applications” filed Jun. 29, 2001, whose inventors are Geoffrey Schmit, Brent Schwan, Jonathan Brumley, Thomas A. Makowski, and Christopher T. Bartz.
BACKGROUND OF THE INVENTION1. Field of the Invention
The present invention relates generally to the field of measurement and automation systems. More particularly, the present invention relates to a measurement system graphical user interface for allowing a user to easily configure measurement and automation applications.
2. Description of the Related Art
Scientists and engineers often use measurement or automation systems to perform a variety of functions, including measurement of a physical phenomenon or unit under test (UUT), test and analysis of physical phenomena, simulation, hardware-in-the-loop testing, process monitoring and control, control of mechanical or electrical machinery, data logging, laboratory research, and analytical chemistry, to name a few examples.
A typical measurement system includes a computer system with a measurement device or measurement hardware. The measurement device may be or include a computer-based instrument, a data acquisition device or board, a programmable logic device (PLD), a sensor, a smart sensor, an actuator, a signal generator, or other type of device for acquiring or generating data. The measurement device may be a card or board plugged into one of the I/O slots of the computer system, a card or board plugged into a chassis, or an external device. For example, in a common measurement system configuration, the measurement hardware is coupled to the computer system via other means such as through a VXI (VME eXtensions for Instrumentation) bus, a PXI (PCI eXtensions for Instrumentation) bus, a GPIB (General Purpose Interface Bus), a serial port, or a parallel port of the computer system. Optionally, the measurement system includes signal conditioning devices which receive the field signals and condition the signals to be acquired.
A measurement system may also typically include transducers, sensors, actuators or other detecting (or generating) means for providing “field” electrical signals representing a process, physical phenomena, equipment being monitored or measured, etc. The field signals are provided to the measurement hardware.
The measurement hardware is configured and controlled by measurement software executing on the computer system. The measurement software for configuring and controlling the measurement system typically comprises two portions: the device interface or driver-level software and the application software, or the application. The driver-level software serves to interface the measurement hardware to the application. The driver-level software may be supplied by the manufacturer of the measurement hardware or by some other third party software vendor. An example of measurement or DAQ driver-level software is NI-DAQ from National Instruments Corporation. The application or client is typically developed by the user of the measurement system and is tailored to the particular function which the user intends the measurement system to perform. The measurement hardware manufacturer or third party software vendor sometimes supplies the application software for certain applications which are common, generic or straightforward.
One drawback of some current measurement system architectures is that complex measurement tasks involving multiple devices require that each device be programmed separately, and that synchronization signals be explicitly routed. Users must typically specify and configure measurement tasks at an advanced level, which is time consuming, expensive, and prone to error. For example, in some prior art systems, users must specify numerous parameter values for channels, timing, and triggering for a measurement task. Typically there is no mechanism for providing default values for the parameters, so that the user must not only know all of the parameters which are needed to specify the task, but must also know what values of the parameters are appropriate for the task. These issues may become more important when multiple devices are utilized to perform the task, in that the number and variety of parameters may increase accordingly.
Additionally, many current measurement systems require that the user perform a significant amount of programming, either in a text-based programming language such as LabWindows or Visual Basic, or in a graphical programming language such as LabVIEW. It would be desirable for a user to be able to more easily create measurement solutions with reduced programming requirements.
Therefore, it would be desirable to provide new systems and methods for specifying and performing measurement tasks.
SUMMARY OF THE INVENTIONA system and method are presented for a measurement system graphical user interface which allows a user to easily configure measurement and automation applications. A measurement task specifier may generate a measurement task specification characterizing a measurement task. The measurement task specifier may display a graphical user interface (GUI) which presents information for guiding the user in specifying the measurement task. The GUI may receive user input characterizing the measurement task, where the user input indicates values for a plurality of parameters of the measurement task. For example, the parameters may include five or more of measurement type, device type, channel parameters, sampling parameters, trigger parameters, clock parameters, scaling parameters, synchronization parameters, routing parameters, and data publishing parameters. The parameter values may be stored in a memory, and analyzed to generate a measurement task specification. The measurement task specification may then be useable to produce a program which implements the measurement task.
The GUI may display a plurality of GUI elements, such as controls and/or indicators, to the user, where each of at least a subset of the plurality of GUI elements presents one or more parameters for the measurement task. As used herein, the term “indicator” refers to any GUI element or component which operates to present information to the user, and the term “control” refers to any GUI element or component which operates to receive input from the user. Examples of GUI elements, i.e., indicators and controls, include panels, menus, tabs, entry fields, buttons, radio buttons, list boxes, active icons, meters, panels, windows, dialog boxes, diagrams, and any other graphical components of a GUI. It is noted that a GUI element may include other GUI elements, such as, for example, a panel which includes one or more indicators and/or controls.
In one embodiment, displaying the graphical user interface may include displaying a plurality of panels which guide the user in specifying the measurement task. The panels presented to the user may be context sensitive, i.e., may depend upon prior user input, or upon prior information presented to the user. For example, the GUI may display a first panel which presents options for specifying values of a first parameter of the measurement task, and receive first user input to the first panel indicating a value of the first parameter. The GUI may then display a second panel which presents information based on the indicated value of the first parameter. The information may indicate a second parameter of the measurement task, and the GUI may receive second user input to the second panel indicating a value of the second parameter of the measurement task. Thus, the particular sequence of panels presented to the user may depend on the user input.
Default values may be provided for at least some of the parameters. For example, the options presented above may include a default value for the first parameter of the measurement task, and the first user input received by the first panel may override the default value with the indicated value, or may indicate acceptance of the default parameter value as the value. Similarly, a default value may be provided for the second parameter, as well, where the second user input may either override the default value of the second parameter with the indicated value of the second parameter, or indicate acceptance of the default value as the value of the second parameter.
In one embodiment, the first panel may present a list of measurement types for the measurement task, and the first user input may indicate a measurement type (from the list) for the measurement task. In response to the first user input specifying the measurement type, the GUI may display a second panel which presents a list of available devices and corresponding channels appropriate for the indicated measurement type, where each of the channels corresponds to a terminal of a corresponding device. In other words, the available devices presented correspond to the indicated measurement type. Second user input may be received by the second panel which indicates one or more channels for a device from the list of available devices and corresponding channels.
The GUI may then display a third panel in response to the second user input, which presents options for specifying values of one or more parameters for the indicated channels. The third panel may receive third user input indicating values of the one or more parameters for the indicated channels. In another embodiment, two or more panel selection controls, e.g., tabs, may be displayed, each corresponding to a respective panel for specifying and/or displaying values of one or more parameters for the indicated channels, e.g., a “settings” panel and a “details” panel. User selection input may be received by one of the two or more panel selection controls, and the respective panel corresponding to the selected panel selection control may be displayed. The selected panel may present options for specifying and/or displaying values of the respective one or more parameters for the indicated channels, and in one embodiment may also receive user input indicating values of the respective one or more parameters for the indicated channels. In one embodiment, the details panel (or its equivalent) may be a “read only” panel which displays parameter values, but which does not allow the values to be set or modified through the panel.
In one embodiment, a device settings panel may be displayed which presents one or more device settings parameters for the measurement task, where the device settings parameters correspond to the selected device. The device settings panel may receive user input indicating values for the presented device settings parameters. A timing panel may also be displayed which presents one or more timing parameters for the measurement task, and which may receive user input indicating values for the presented timing parameters. Similarly, a triggering panel may be displayed which presents one or more triggering parameters for the measurement task, and which may receive user input indicating values for the presented triggering parameters. Thus, a plurality of panels may be displayed for presenting various parameters for the measurement task, and for receiving user input specifying values for the parameters.
In one embodiment, the GUI may also display a help panel which presents context sensitive information related to the measurement task, e.g., information related to other panels (of the plurality of panels). The information presented may be based on which of the other panels are currently displayed. For example, if a panel is displayed which presents channel parameters, the help panel may display information related to the channel parameters, or instructions for specifying values for the channel parameters.
Thus, the GUI may guide the user through a process for specifying values for a plurality of parameters for the measurement task. As mentioned above, the measurement task specifier may then generate a measurement task specification based on the specified parameters, where the measurement task specification is useable to produce a program which implements or performs the measurement task.
In one embodiment, the measurement task specifier may programmatically generate the program which implements the specified measurement task. For example, the GUI may present an option to programmatically generate a program implementing the specified measurement task, and the user may select the option, thereby requesting generation of the program. The measurement task specifier may then generate the program based on the parameter values specified for the measurement task. In another embodiment, the measurement task specifier may generate the program based on the measurement task specification.
The programmatically generated program may be a graphical program, such as a LabVIEW graphical program. A block diagram of the generated program may then be displayed by the GUI, e.g., on a program panel.
In one embodiment, programmatically generating the program may include an expert system analyzing the measurement task specification, and generating a run-time specification for the measurement task in response to the analyzing. The expert system may also validate the measurement task specification prior to generating the run-time specification. A run-time builder may then analyze the run-time specification, and generate a run-time based on the run-time specification. The generated run-time may be executable to perform the measurement task in accordance with the parameters and device(s) specified, i.e., in accordance with the measurement task specification.
A better understanding of the present invention may be obtained when the following detailed description of the preferred embodiment is considered in conjunction with the following drawings, in which:
While the invention is susceptible to various modifications and alternative forms, specific embodiments thereof are shown by way of example in the drawings and will herein be described in detail. It should be understood, however, that the drawings and detailed description thereto are not intended to limit the invention to the particular form disclosed, but on the contrary, the intention is to cover all modifications, equivalents and alternatives falling within the spirit and scope of the present invention as defined by the appended claims.
DETAILED DESCRIPTION OF SEVERAL EMBODIMENTS Incorporation by ReferenceU.S. application Ser. No. 10/008,792 titled “Measurement System Software Architecture for Easily Creating High-Performance Measurement Applications” filed Nov. 13, 2001, and whose inventors are Geoffrey Schmit, Brent Schwan, Jonathan Brumley, Thomas A. Makowski, and Christopher T. Bartz, and which issued as U.S. Pat. No. 6,879,926, is hereby incorporated by reference as though fully and completely set forth herein.
U.S. Provisional Application Ser. No. 60/301,785 titled “Measurement System Software Architecture for Easily Creating High-Performance Measurement Applications” filed Jun. 29, 2001, and whose inventors are Geoffrey Schmit, Brent Schwan, Jonathan Brumley, Thomas A. Makowski, and Christopher T. Bartz is hereby incorporated by reference as though fully and completely set forth herein.
FIG. 1—Computer System
As shown in
The computer system 102 may include a memory medium(s) on which one or more computer programs or software components according to one embodiment of the present invention may be stored. For example, the memory medium may store one or more software programs which are executable to perform the methods described herein. Also, the memory medium may store a programming development environment application used to create and/or execute measurement software programs. The memory medium may also store operating system software, as well as other software for operation of the computer system.
The term “memory medium” is intended to include various types of memory or storage, including an installation medium, e.g., a CD-ROM, floppy disks, or tape device; a computer system memory or random access memory such as DRAM, SRAM, EDO RAM, Rambus RAM, etc.; or a non-volatile memory such as a magnetic media, e.g., a hard drive, or optical storage. The memory medium may comprise other types of memory or storage as well, or combinations thereof. In addition, the memory medium may be located in a first computer in which the programs are executed, or may be located in a second different computer which connects to the first computer over a network, such as the Internet. In the latter instance, the second computer may provide program instructions to the first computer for execution.
In addition, the memory medium may be located in a first computer, e.g., computer system 102, or may be located in a second different computer which connects to the first computer over a network, such as the Internet, as described below with reference to
FIG. 2—A Network System
As used herein, the term “distributed system” is intended to include a system comprising two or more interconnected or coupled devices, i.e., two or more devices that are coupled together in some fashion. The two or more devices may be coupled together via wired or wireless means. Wired means may include a network, such as a local area network (LAN) and/or a wide area network (WAN), such as the Internet, a computer bus, a serial or parallel bus, or other wired communication methods. Example local area networks include Ethernet networks, Token Ring networks, and various industrial communication networks such as fieldbus, DeviceNet, and CAN (Controller Area Network) networks. Example parallel buses include the PCI bus, PXI bus, GPIB, and VXI bus, among others. Example serial buses include USB (Universal Serial Bus), IEEE 1394, RS-242, and RS-485, among others. Wireless means may include wireless protocols such as IEEE 802.11 (wireless Ethernet), Bluetooth, and other types of wireless communication.
In one embodiment, the server 106 may store programs, applications, or data which may be accessed or retrieved by the host computer system 102. Thus, the server 103 may store measurement task specification software or information, for example, in a database or library. The computer system 102 may access the server 106 to retrieve data or execute software to implement various embodiments of the system and method described herein.
FIGS. 3A and 3B—Instrumentation and Industrial Automation Systems
As used herein, the term “measurement system” is intended to include an instrumentation system such as that shown in
The host computer 102 may execute a program which interacts with or controls the one or more instruments. The one or more instruments may include a GPIB instrument 112 and associated GPIB interface card 122, a data acquisition board 114 and associated signal conditioning circuitry 124, a VXI instrument 116, a PXI instrument 118, a video device or camera 132 and associated image acquisition card 134, a motion control device 136 and associated motion control interface card 138, and/or one or more computer based instrument cards 142, among other types of devices. Note that the computer based instrument card 142 may be a board or card with one or more FPGAs, one or more CPUs and memory, or various combinations of the two.
The GPIB instrument 112 may be coupled to the computer 102 via the GPIB interface card 122 provided by the computer 102. In a similar manner, the video device 132 may be coupled to the computer 102 via the image acquisition card 134, and the motion control device 136 may be coupled to the computer 102 through the motion control interface card 138. The data acquisition board 114 may be coupled to the computer 102, and may interface through signal conditioning circuitry 124 to the UUT. The signal conditioning circuitry 124 may comprise an SCXI (Signal Conditioning eXtensions for Instrumentation) chassis comprising one or more SCXI modules 126.
The GPIB card 122, the image acquisition card 134, the motion control interface card 138, and the DAQ card 114 are typically plugged in to an I/O slot in the computer 102, such as a PCI bus slot, a PC Card slot, or an ISA, EISA or MicroChannel bus slot provided by the computer 102. However, these cards 122, 134, 138 and 114 are shown external to computer 102 for illustrative purposes. These cards 122, 134, 138, 114 may also connected to the computer 102 through a USB (Universal Serial Bus), IEEE 1394 or 1394.2 bus provided by the computer 102.
The VXI chassis or instrument 116 may be coupled to the computer 102 via a VXI bus, MXI bus, or other serial or parallel bus provided by the computer 102. The computer 102 may include VXI interface logic, such as a VXI, MXI or GPIB interface card (not shown), which interfaces to the VXI chassis 116. The PXI instrument may be coupled to the computer 102 through the computer's PXI bus. The PXI chassis may be coupled to the computer 102 via a MXI-3 bus.
A serial instrument (not shown) may also be coupled to the computer 102 through a serial port, such as an RS-232 port, USB (Universal Serial bus) or IEEE 1394 or 1394.2 bus, provided by the computer 102.
In typical instrumentation control systems an instrument of each interface type may not be present, and in fact many systems may only have one or more instruments of a single interface type, such as only GPIB instruments. The instruments are coupled to the unit under test (UUT) or process 150, or are coupled to receive field signals, typically generated by transducers. The system 100 may be used in a data acquisition and control application, in a test and measurement application, a process control application, a man-machine interface application, or a simulation application.
The one or more devices may include a data acquisition board 114 and associated signal conditioning circuitry 124, a PXI instrument 118, a video device 132 and associated image acquisition card 134, a motion control device 136 and associated motion control interface card 138, a FieldBus device 170 and associated FieldBus interface card 172, a PLC (Programmable Logic Controller) 176, a serial instrument 182 and associated serial interface card 184, or a distributed data acquisition system, such as the FieldPoint system available from National Instruments, among other types of devices.
The DAQ card 114, the PXI chassis 118, the video device 132 and image acquisition card 134, and the motion control device 136 and motion control interface card 138 may be coupled to the computer 102 as described above. The serial instrument 182 may be coupled to the computer 102 through a serial interface card 184, or through a serial port, such as an RS-232 port, provided by the computer 102. The PLC 176 may couple to the computer 102 through a serial port, Ethernet port, or a proprietary interface. The FieldBus interface card 172 may be comprised in the computer 102 and interfaces through a FieldBus network to one or more FieldBus devices. Each of the DAQ card 114, the serial card 184, the FieldBus card 172, the image acquisition card 134, and the motion control card 138 are typically plugged in to an I/O slot in the computer 102 as described above. However, these cards 114, 184, 172, 134, and 138 are shown external to computer 102 for illustrative purposes. In typical industrial automation systems a device will not be present of each interface type, and in fact many systems may only have one or more devices of a single interface type, such as only PLCs. The devices are coupled to the device or process 150.
Referring again to
In one embodiment, the software programs and software architecture as described herein may be designed for measurement systems, including data acquisition/generation, analysis, and/or display; automation systems; simulation systems; systems for controlling, modeling, or simulating instrumentation or industrial automation hardware; and systems for controlling, modeling or simulating systems or devices being designed, prototyped, validated or tested. However, it is noted that the present invention can be used for a plethora of applications and is not limited to instrumentation or industrial automation applications. In other words,
FIG. 4—Computer System Block Diagram
The computer 102 includes at least one central processing unit or CPU 160 which is coupled to a processor or host bus 162. The CPU 160 may be any of various types, including a x86 processor, e.g., a Pentium class; a PowerPC processor; a CPU from the SPARC family of RISC processors; as well as others. Main memory 166 is coupled to the host bus 162 by means of memory controller 164. The main memory 166 may store one or more computer programs or libraries according to one embodiment of the present invention. The main memory 166 also stores operating system software as well as the software for operation of the computer system, as well known to those skilled in the art.
The host bus 162 is coupled to an expansion or input/output bus 170 by means of a bus controller 168 or bus bridge logic. The expansion bus 170 is preferably the PCI (Peripheral Component Interconnect) expansion bus, although other bus types can be used. The expansion bus 170 includes slots for various devices such as the data acquisition board 114 (of
1) a processor and memory which is capable of being configured by a user or software program; and/or
2) reconfigurable logic, such as an FPGA (Field Programmable Gate Array).
For more information on a reconfigurable instrument which includes an embedded processor and embedded memory, please see U.S. Pat. No. 6,173,438 which is hereby incorporated by reference in its entirety as though fully and completely set forth herein. For more information on a reconfigurable instrument which includes reconfigurable hardware, e.g., an FPGA, please see U.S. Pat. No. 6,219,628 which is hereby incorporated by reference in its entirety as though fully and completely set forth herein. The computer 102 may further comprise a video display subsystem 180 and hard drive 182 coupled to the expansion bus 170.
FIG. 5—Creating a Measurement Solution
As shown, the application 202 communicates with a measurement driver 212. The measurement driver 212 may include a measurement driver application programming interface (API) 214. As shown, the application program 202A or 202B interfaces with the measurement driver API 214 in order to access capabilities of the measurement driver 212. In this measurement example, the software architecture may also include interchangeable virtual instrument (IVI) drivers 222 wherein the application program 202B may interface through IVI drivers 222, which interface with the measurement driver API 214, to interface with the measurement driver 212.
The measurement driver 212 interfaces to the one or more various measurement devices 230 comprised in this system. The measurement devices 230 may comprise any of the various devices discussed above with respect to
In one embodiment, the present invention provides an improved system and method for creating application programs, such as application programs 202A and 202B. The measurement driver 212 preferably includes various software that may allow creation of an application program 202A or 202B using a high-level interface and requiring reduced user effort and coding.
FIG. 6—Measurement Driver Program Components
As
In one embodiment, the measurement task specification 740 may comprise software objects or data structures, such as C++ objects, which may specify the measurement task. In one embodiment, the measurement task specifier 730 may be a measurement task wizard, i.e., a software program which leads the user through a measurement task specification process to create the measurement task specification 740. In another embodiment, the measurement task specifier 730 may take the form of a measurement task configuration tool, which is a software program invocable by the user under a development environment, such as the National Instruments LabVIEW environment or Measurement Studio programming development environment. In yet another embodiment, the measurement task specifier 730 may simply be an API through which the user makes calls to generate the task specification. Thus, in various embodiments, the measurement task specifier 730 may generate the measurement task specification 740 in response to user input.
As shown, an expert system 750 may use the measurement task specification 740 to generate a run-time specification 770. The expert system 750 may include a plurality of experts. The expert system 750 may include one or more experts for each of the measurement device types shown in
In one embodiment, the run-time specification 770 may similarly comprise software objects or data structures, such as C++ objects, which may specify the run-time parameters for software and/or hardware used to implement the specified measurement task. The run-time specification 770 may comprise parameter specifications for one or more measurement primitives 408 which correspond to rudimentary measurement tasks or operations. Said another way, the run-time specification 770 may comprise a collection of primitive settings, each of which may comprise a detailed and unambiguous “recipe” for a primitive. For example, primitive settings for a digitizer, such as a National Instruments E-Series digitizer, may include: Dither (Yes, No), Polarity (Bi-polar, Uni-polar), Gain, Mode (Calibration, Differential, Non-Referenced Single-Ended, Referenced Single-Ended, Auxillary, Ghost), Generate Trigger (Yes, No), and Last Channel (Yes, No).
The run-time specification 770 may in turn be interpreted by the run-time builder 780 to generate a run-time 790, which may be executable to perform the specified measurement task. More details of the operation of the measurement driver program are presented below with reference to
FIG. 7—Method For Performing A Measurement Task
As shown, in step 502 a user may optionally install measurement hardware within the system. This may comprise connecting a measurement device to the computer system or installing a measurement card or board within a slot of the computer system. This may further comprise installing a measurement card or board in a slot of a chassis, such as a PXI chassis, which itself is coupled to the computer system and/or which may contain a computer system comprised on a card within the chassis. In one embodiment, the measurement hardware may comprise a “reconfigurable measurement device” which may be operable to be reconfigured “on the fly” during a measurement task or operation. For example, the reconfigurable measurement device may include a processor and memory or an FPGA that may be reconfigured with different measurement programs or tasks.
In step 504 the computer system and/or the user may optionally configure the measurement hardware device(s). This may involve operation of standard Plug & Play software to recognize the measurement device and select setting or parameters for the device. It should be noted that in many instances, the user may not be required to perform 502 and/or 504 before generating the measurement task. In other words, the measurement hardware may already be installed and configured and the user may proceed with the configuration and specification of the measurement task in step 506. In another embodiment, “stub” interfaces may be provided, e.g., in software, which emulate the presence of measurement devices, allowing the user to design or specify the measurement task without actually installing the necessary hardware and/or software.
In step 506 the user may invoke the measurement task specifier 730 to configure a desired task in the measurement driver 212, thereby producing a measurement task specification 740. In the preferred embodiment, the measurement task specifier 730 includes an interactive Graphical User Interface (GUI) configuration tool which enables the user to easily and simply configure a desired measurement task. This may involve selecting various parameters of the task such as the type of measurement being performed, e.g., voltage, current, etc., and other measurement settings.
In one embodiment, once the task has been specified, the user may add specification objects, modules, or code, specifying start, read/write, and/or cleanup operations to the task specification. In one embodiment, once the task has been specified, the user may request the task specifier 730 to generate code. The task specifier may then programmatically generate code specifying start, read/write, and/or cleanup operations, among others. In various embodiments, this generated code may comprise one or more icons in a LabVIEW graphical program (i.e., VIs), as described in more detail below, and/or function calls in a text-based program including one or more of C code, C++ code, C# code, Java code, Visual Basic code, or any other form of computer program code, which may specify support operations needed to implement the specified measurement task. In one embodiment, the generated code may comprise icons representing some or all of the specified measurement task operations, including clocking and trigger operations, among others. In one embodiment, the task specifier 730 may generate the icons and connect them together appropriately. In another embodiment, the task specifier 730 may generate the icons, but the user may be required to link the icons appropriately. Thus, in one embodiment, the method may include generating a measurement task diagram in response to user input specifying the measurement task. In one embodiment, the measurement task diagram may comprise a graphical program, such as a LabVIEW graphical program. Further details of programmatic generation of a graphical program are presented below with reference to
It should be noted that a node for use in a graphical program typically includes a graphical icon which may be displayed in the graphical program to visually represent the node in the graphical program. A node for use in a graphical program may also include underlying program instructions and/or data structures which perform the functionality of the node. When the present application states that a node performs a function, it is understood that the program instructions and/or data structures of the node actually perform this function. Thus, the graphical icon that visually represents the node represents the function, and the underlying program instructions and/or data structures which are represented by the node graphical icon are actually performing the function. Thus the specification and claims of the present application refer generally to a node performing a function, it being understood that the node includes or represents underlying program instructions and/or data structures which are executed by a processor (or programmable hardware element) to perform the function.
In another embodiment, the user may specify the task manually. For example, the user may use a graphical programming development environment such as LabVIEW to place one or more icons or nodes on the display and connect them in a desired way to accomplish the desired result. In one embodiment, the user may select a small number of function icons or nodes, such as a measurement read node or measurement write node, to accomplish the configured measurement task. As another example, the user may use the Measurement Studio programming development environment from National Instruments Corporation (e.g., LabWindows/CVI) to create a text-based program to accomplish the measurement task. This text-based program would typically comprise very few lines of code. Thus, complex measurement procedures may be encapsulated and represented by simple icons or function calls, allowing the user to rapidly and easily create measurement “programs” to implement or carry out complex measurement operations.
In one embodiment, the measurement task specifier 730 may comprise a measurement task wizard. In other words, the measurement task specifier 730 may be a software program which leads the user through a measurement task specification process, thereby generating the measurement task specification 740. In another embodiment, the measurement task specifier 730 may comprise a measurement task configuration tool. The measurement task configuration tool may be a software program invocable by the user within a development environment, such as National Instruments' LabVIEW environment, Measurement Studio programming development environment, or any other development environment. For example, the user may specify or configure a measurement task by placing or “dropping” nodes or icons on a graphical diagram and connecting the nodes via virtual “wires” to generate a graphical diagram or model of the measurement task. The graphical development environment program (e.g., LabVIEW) may generate software objects or data structures corresponding to the components of the graphical diagram which specify the measurement task. These data structures may comprise the measurement task specification 740. In one embodiment, at this stage the measurement task specification 740 is not executable per se, but provides information which may be used by other components of the system to generate a measurement application suitable to carry out the measurement task, i.e., to implement the specified measurement operation.
In another embodiment, the measurement task specifier 730 may be an API through which the user makes calls to generate the task specification. For example, the user may make API function calls in a C++ application program to specify the various attributes or aspects of the desired measurement task, such as measurement type (voltage, current, pressure, etc.), timing or sampling parameters, or other measurement task specification information. The executed functions may produce corresponding data structures which contain specification information for the measurement task. When the application program 202 is executed, the API function calls may generate the measurement task specification 740, which may then be used later in the execution process to produce the run-time specification, as described below.
In step 508 an expert system comprised in the measurement driver may operate to receive the measurement task specification 740, then analyze the measurement task specification 740, validate the measurement task specification 740, and create a run-time specification 770 based on the measurement task specification 740. The run-time specification 770 preferably comprises parameter settings for one or more measurement devices and other hardware comprised within the system, and may also specify software components or software programs which are to be used during execution of the task. In one embodiment, the run-time specification 770 may comprise a specification of the parameters of one or more measurement primitives, where each measurement primitive comprises a software object and corresponding configuration settings, and where each measurement primitive is operable to implement at least a portion of the measurement task. Thus, the run-time specification 770 may be useable to configure one or more measurement devices to perform the measurement task, and may be further useable to generate a run-time 790 which is executable to perform the measurement task using the configured one or more measurement devices. The measurement driver 212 may include expert system 750 comprising the plurality of experts 406 where one or more experts 406 are available for each of the various types of measurement tasks or sub-tasks. Thus, depending upon the type of measurement task configured by the user in step 506, one or more corresponding experts 406 may be invoked to create the run-time specification. In one embodiment, multiple experts may each produce a candidate run-time specification. Thus, the measurement task specification 740 may be used in step 508 to ensure that the measurement task can operate as configured by the user.
In one embodiment, one or more of the generated measurement task specification 740, the generated run-time specification 770, and configuration information for the one or more measurement devices may be stored, such as in a memory medium, e.g., a computer system's RAM or persistent storage medium.
In one embodiment, the run-time builder 780 may analyze the selected run-time specification 770, and then reserve one or more resources, such as hardware and/or software, according to the selected run-time specification 770. The run-time builder 780 may also un-reserve resources if the analysis of the selected run-time specification indicates that previously reserved resources are no longer needed to implement the measurement task. In another embodiment, the run-time builder 780 may handle abnormal process termination and/or unexpected device removal.
In step 510 a run-time 790 may be created which embodies or implements the measurement task configured in step 506 based on the generated (and/or selected) run-time specification 770. In one embodiment, the run-time 790 may comprise a collection of measurement operation primitives (or instances of measurement operation primitives) sequenced together which are executable to implement the measurement task.
When the user (or software program) enters input to execute or run the program, the measurement driver 212 may invoke the run-time builder program. The run-time builder program operates to access the run-time specification and use the parameters and data contained in the run-time specification to assist in creating the run-time at run time. In one embodiment, the run-time builder uses the run-time specification to instantiate instances of various objects or primitives comprised in the measurement driver 212. After the run-time builder instantiates various instances of objects, the run-time builder may apply various parameters from the run-time specification to these object instances. The run-time builder may also provide various parameters to hardware and/or software resources or devices comprised in the system to configure the hardware and/or software devices in the system according to the run-time specification to allow these devices to be used during execution of the run-time 790. In other words, the run-time builder 780 may configure one or more measurement devices according to the run-time specification 770. After the run-time builder 780 has completed creating the run-time 790, the run-time may be executable to perform the task specified by the user.
After step 510 the user (or a software program) may execute the run-time 790 to perform the measurement task. In other words, the run-time execution may invoke the various configured hardware and/or software components to perform the specified measurement task.
It should be noted that the above method, described in terms of a measurement task, may also be applied to other types of tasks, as well, including, but not limited to, machine vision, scientific, engineering, financial, business, e-commerce, and medical tasks, among others.
Further details of the program generation are described below with reference to
Examples of Measurement Problems
Below are listed several example problems suitable for solution by various embodiments of the present invention. It should be noted that these solutions are for example purposes only, and are not intended to limit the domains of application of the present invention.
1. Point of Sale Configuration: Given all the hardware and software in the National Instruments catalog and a single computer, determine a set of hardware, hardware connections, hardware settings, and software configuration that can maintain a level in a tank (whose simulated linear model is specified to be M) by monitoring the present value of the tank level and controlling a valve connected to the tank. The solution should display the tank level and valve position on an HMI. Constraints include cost<$10000 and standard deviation of the tank level<D. Preference is for the lowest cost solution.
2. Out of the Box Configuration: Given 2 thermocouples, a National Instruments SCXI 1102 module, a National Instruments SCXI-1000 chassis, a National Instruments PCI-MIO-XE-50, and a set of appropriate terminal blocks cabling, determine the hardware connections (in the form of a wiring diagram), hardware settings, and software configuration for monitoring the two temperature values at a rate of 10 Hz each, with an accuracy=A and precision=P for each temperature measurement.
3. Run-time Configuration: Given a high-frequency switch connected to three 2-channel scopes, determine the hardware settings and software configuration for measuring the waveform, overshoot, and rise time of a set of five simultaneous 10 MHz digital clock signals connected to the switch. The accuracy and precision of the measurements must meet certain requirements, and all 5 measurements should be synchronized to a start event which is triggered by a high level of the first digital clock. (The solution should take into account the signal delays from various routings through the switch).
In various embodiments, the present invention may include some or all of the following features:
1. Interactive design—the user may not have to specify a complete specification up front. Instead, the system may ask the user for more information as needed. For instance, while the system is building a solution, it may encounter one or more possibilities and may ask the user to specify new preferences at that point.
2. Graphical and visual display of system specifications and realizations (including text-based displays where appropriate)—The system may display realizations so that they can be edited directly.
3. Extensibility—ability to add new measurement methods/drivers to the system and use those methods in a derived realization as the system evolves over time to include more domains. The user is able to participate in this process by adding custom measurement methods. The system may be extended with new measurement methods/drivers in multiple independent efforts (i.e. with independent releases). Groups of extensions may be packaged with different products and installed separately.
4. Visibility—ability for the user to see solutions generated by the system and extend and modify those solutions.
5. Robustness—ability to detect and help correct invalid specifications and invalid realizations.
The features mentioned above may allow the user to specify and execute a measurement task in substantially less time and with substantially less effort than previous methods. In addition, the system described may prevent the user from implementing a measurement solution which is inappropriate for the available resources. Further details of the system design, architecture, and operation are described below with reference to
FIG. 8—Method For Specifying A Measurement Task
As
In one embodiment, displaying the graphical user interface may include displaying a plurality of GUI elements, such as controls or indicators, to the user, where each of at least a subset of the plurality of GUI elements presents one or more parameters for the measurement task. As used herein, the term “indicator” refers to any GUI element or component which operates to present information to the user, and the term “control” refers to any GUI element or component which operates to receive input from the user. Examples of GUI elements, i.e., indicators and controls, include panels, menus, tabs, entry fields, buttons, radio buttons, list boxes, active icons, meters, panels, windows, dialog boxes, diagrams, and any other graphical components of a GUI. It is noted that a GUI element may include other GUI elements, such as, for example, a panel which includes one or more indicators and/or controls.
In another embodiment, displaying the graphical user interface may include displaying a plurality of panels which guide the user in specifying the measurement task. Note that as used herein, the term “panel” refers to a graphical region of the GUI which includes one or more controls for receiving user input and/or indicators for presenting information to the user. Thus, a panel may be any of a dialog box, an alert box, a list box, a window, a screen, a pop-up menu, or any other functional graphical area of the GUI. Thus, the GUI may comprise one or more panels. In the descriptions that follow, the GUI is described in terms of panels, although it is noted that other GUI elements are also contemplated for implementing various embodiments of the measurement task specifier.
In a preferred embodiment, the particular sequence of panels or GUI elements presented to the user may depend upon the user input. In other words, the presentation of panels or GUI elements may be context sensitive. Additionally, the information presented by a given GUI element, e.g., a panel, may itself be context sensitive. Examples of such context sensitivity are described below.
In 804, the graphical user interface may receive user input characterizing the measurement task. The user input may indicate parameter values for a plurality of parameters of the measurement task, such as, for example, measurement type, device type, channel parameters, sampling parameters, trigger parameters, clock parameters, scaling parameters, synchronization parameters, routing parameters, and data publishing parameters, among others. In one embodiment, the user input may indicate values for five or more of these parameters to characterize the measurement task. Various embodiments of the method are described below. Additionally, a step-by-step example of one embodiment of the method steps 802 and 804 is presented below with reference to
In 806, the parameter values may be stored in a memory. As mentioned above, the memory may be comprised on the host computer 102, or on a system coupled to the host computer, such as server computer 106. In one embodiment, the parameter values indicated by the user (including any default values used) may be stored in a temporary location during the specification process, then moved to a different storage location, e.g., long term storage, when the user “saves” the configuration. For example, the user may select a “save” option, or the measurement task specifier may automatically save on exit. In another embodiment, the parameter values may be stored as they are entered, and modified as needed based on subsequent user input.
In 808, the parameter values may be analyzed, then in 810, a measurement task specification may be generated based on the analysis. The measurement task specification may be useable to produce a program which implements the measurement task, as described with reference to
As mentioned above, in one embodiment, the GUI may present a plurality of panels to the user which may interactively guide the user through the specification process. As also mentioned above, at least a subset of the panels may be context sensitive. For example, in one embodiment, the GUI may display a first panel which presents options for specifying values of a first parameter of the measurement task. The GUI may then receive first user input to the first panel indicating a value of the first parameter. The GUI may then display a second panel which presents information based on the indicated value of the first parameter. In one embodiment, the information may indicate a second parameter of the measurement task. The GUI may then receive second user input to the second panel indicating a value of the second parameter of the measurement task. Thus, the GUI may display various context sensitive panels for configuring parameters associated with the measurement task in response to user input. As another example, the GUI may display context sensitive help information, where the help information displayed is based on which of the plurality of panels or other GUI elements are currently displayed.
In one embodiment, one or more of the panels may include default values for one or more parameters of the measurement task. For example, the presented options may include a default value for the first parameter of the measurement task. In this case, the first user input to the first panel may override the default value with the input value, or may indicate acceptance of the default parameter value as the input value. Similarly, the information presented by the second panel may include a default value for the second parameter of the measurement task. The second user input to the second panel may then either override the default value of the second parameter with the value of the second parameter, or may indicate acceptance of the default parameter value of the second parameter as the value of the second parameter. It should be noted that the default values may be utilized without explicitly being presented to the user by a panel. For example, if the user sets values for a minimal required set of input parameters for a measurement task, the remainder of the parameters may assume the default values provided by the system, i.e., panels associated with the remainder of the parameters needn't be displayed for the default parameter values to be put into effect.
Various embodiments of the process of specifying the measurement task using the GUI are described below. As noted above, the GUI's use of panels as GUI elements is intended to be exemplary, and is not intended to limit the form or mechanisms of the GUI to any particular type of GUI element.
In one embodiment, the GUI may display a first panel, e.g., a measurements type panel, which may present a list of measurement types for the measurement task. For example, the list may include one or more of: acceleration, current, frequency, resistance, strain, voltage, and temperature, among others. Of course, these measurement types are intended as examples only, and any and all other measurement types are also contemplated as being in the scope of the present invention. As noted above, the measurement types may also include signal generation, e.g., voltage output. An example of the GUI's presentation of measurement types is shown in
In response to the first user input, the GUI may display a second panel, e.g., a channels selection panel, which presents a list of available devices and corresponding channels. The available devices may correspond to the indicated measurement type. For example, if the selected measurement type were voltage, the devices listed may be those devices available to the system which are suitable for measurement a voltage. An example of the device and channel list is shown in
The GUI may then receive second user input to the second panel indicating one or more channels for a device from the list of available devices and corresponding channels, an example of which is shown in
In response to the second user input, the GUI may display a third panel, e.g., a channel configuration panel, which presents options for specifying values of one or more parameters for the indicated channel(s). Examples of parameters for channel configuration include input range (or output range in the case of signal generation) and units, e.g., voltage, current, etc., as well as channel parameters specific to a particular measurement type, such as, for example, bridge type for strain measurements, and excitation source, sensitivity, and resonant frequency for an acceleration measurement. The GUI may then receive third user input to the third panel indicating values of the one or more parameters for the indicated channel(s). For examples of channel configuration panels, see
In one embodiment, a plurality of panels may be presented for specifying a set of parameters, where the parameters are grouped in subsets. For example, in one embodiment, basic channel parameters, such as input range and units, may be presented by a “settings” panel, while further channel parameters may be presented by a “details” panel, such as, for example, scaling parameters which specify a scaling function to be applied to the channel data. In one embodiment, the GUI may display two or more panel selection controls, e.g., tabs, each of which may correspond to a respective panel for specifying values of one or more parameters for the indicated channel(s). In this embodiment, the GUI may receive user selection input to one of the two or more panel selection controls, e.g., one of the tabs may be selected by the user.
In response to the user selection input, the GUI may display the respective panel corresponding to the selected panel selection control. The respective panel may present options for specifying values of the respective one or more parameters for the indicated one or more channels. The GUI may then receive user input to the respective panel indicating values of the respective one or more parameters for the indicated one or more channels. In one embodiment, the details panel (or its equivalent) may be a “read only” panel which displays parameter values, but which does not allow the values to be set or modified through the panel.
In one embodiment, the GUI may display a timing panel, which presents one or more timing parameters for the measurement task. The GUI may then receive user input to the timing panel indicating values for the one or more timing parameters for the measurement task. The GUI may also display a triggering panel which presents one or more triggering parameters for the measurement task. The GUI may then receive user input to the triggering panel indicating values for the one or more triggering parameters for the measurement task. In one embodiment, the timing and triggering panels may be a single panel. For examples of timing and triggering panels, please see
In one embodiment, the GUI may display a device settings panel which presents one or more device settings parameters for the measurement task. The device settings parameters may correspond to the device selected from the channel selection panel, described above. Thus, the device settings panel may be presented in response to the user input which selected the device (and channels). The GUI may then receive user input to the device settings panel indicating values for the one or more device settings parameters for the measurement task. One example of a device settings panel is described below with reference to
Thus, as described above, the measurement task specifier 730, i.e., the configuration tool 730, may be operable to guide the user in specifying parameter values for the measurement task. As mentioned above in 808 and 810, the task specifier 730 may then analyze the parameters and generate a measurement task specification 730.
In one embodiment, the GUI may present an option to programmatically generate a program implementing the specified measurement task, for example, based on the generated measurement task specification. In another embodiment, the program may be generated based on the parameters received from the user (and any default values provided by the measurement task specifier). As mentioned above, in various embodiments, the program generated may be a graphical program, such as a LabVIEW graphical program, a text-based program, such as a C program, or any other kind of program which is operable to perform the specified measurement task. Thus, in response to receiving user input selecting the option to generate the program, the configuration tool 730 may programmatically generate the program based on the parameter values described above.
In one embodiment, the generated program may be executable to perform the measurement task. In another embodiment, the generated program may comprise a source program which is usable to generate an executable program.
In the case where the generated program is a graphical program, the GUI may display a program panel comprising a block diagram of the graphical program, e.g., a LabVIEW graphical program block diagram. The execution of the graphical program may invoke one or more processes to generate an executable run-time 790 which performs the specified measurement task using the device(s) specified for the task.
In one embodiment, programmatically generating the program based on the parameter values may include an expert system 750 analyzing the measurement task specification 740, and generating a run-time specification 770 for the measurement task in response to the analyzing. In one embodiment, the expert system 750 may validate the measurement task specification 740 prior to generating the run-time specification 770.
A run-time builder 780 may then analyze the run-time specification 770, and generate a run-time 790 based on the run-time specification 770, where the run-time 790 is executable to perform the measurement task. In one embodiment, the run-time builder 780 may configure one or more measurement devices (i.e., the devices specified in the measurement task configuration) according to the run-time specification 770. The run-time 790 may then be executable to perform the measurement task using the configured measurement devices.
The embodiments described above are but examples of some of the measurement task configuration parameters which may be specified using the configuration tool 730, i.e., the measurement task specifier 730. It is further noted that although numerous panels were described for presenting and specifying parameters, in other embodiments, different panel/parameter groupings may be used. For example, in one embodiment, a single panel may be presented which displays most or all of the configurable parameters. In one embodiment, the single panel may add or modify various indicators and/or controls in response to user input, dynamically presenting appropriate parameters in response to the user's input.
FIG. 9—High-Level Architecture
FIG. 10A-D—Static Diagrams of the System
FIG. 10A—System for System Configuration and Task Specification
As
In one embodiment, interactive and application programming interfaces (IAPIs) 730 may be used to access various objects and functions of the system. These interfaces may provide mechanisms through which the user, other system components, or other systems, may specify a measurement task. As
The IAPIs may further include measurements APIs for various development environments or languages, such as a measurements API for LabVIEW 718 and MIO extensions to measurements API for LabVIEW 722, which may be operable to extend the measurements API for LabVIEW 718; a measurements API for C 728 and MIO extensions to measurements API for C 732, which may be operable to extend the measurements API for C 728; a measurements API for Measurement Studio Tools for Visual C++ 724 and MIO extensions to measurements API for Measurement Studio Tools for Visual C++ 726, which may be operable to extend the measurements API for Measurement Studio Tools for Visual C++ 724; and a measurements API for Measurement Studio Tools for Visual Basic 734 and MIO extensions to measurements API for Measurement Studio Tools for Visual Basic 736, which may be operable to extend the measurements API for Measurement Studio Tools for Visual Basic 734. It should be noted that in other embodiments, other interfaces or APIs may be included for other development environments and/or programming languages.
As
Thus, the system components described above may allow the user to configure the system, as well as to generate a measurement task specification 740.
FIG. 10B—System for Compiling a Task Specification to a Task Run-Time Specification
In one embodiment, the expert system 750 may be operable to retrieve system configuration information from the system configuration storage 710 to make decisions regarding the measurement task specification 740. The expert system 750 may be further operable to compile the task specification 740 to produce the task run-time specification 770, as shown. As
As
As mentioned above, the expert system 750 may produce the task run-time specification based on the task specification 740, the system configuration information stored in the system configuration storage 710, and the various experts comprised in the expert system 750. In one embodiment, the task run-time specification 770 may include various primitive settings specified by one or more of the above-mentioned experts. For example, the settings may include measurements run-time primitive settings 772, measurements streaming primitive settings 774, routing primitive settings 776, and MIO primitive settings 778. The primitive settings may each be stored in MXS 712, as shown.
Note that when the measurement task specification does not specify any product-specific properties, i.e., any properties or specifications particular to a given device or product, then the measurement task specification may be compiled to various different measurement systems without modification. In other words, to the extent that the measurement task specification is generic, it is also portable, and thus a single measurement task specification may be used or compiled for multiple measurement systems.
FIG. 10C—System for Building a Task Run-Time From a Task Run-Time Specification
In one embodiment, the run-time builder 780 may include a measurements run-time builder 782 which may be operable to create primitive supervisors for each primitive setting in the run-time specification 770, such as measurements run-time primitive supervisors 784, MIO primitive supervisors 786, measurements streaming primitive supervisors 788, and routing primitive supervisors 789. As
In one embodiment, the task run-time 790 may include a measurements run-time 792 which may manage routing primitives and supervisors 794, MIO primitives and supervisors 796, measurements streaming primitives and supervisors 798, and measurements run-time primitives and supervisors 799. The task run-time 790 may be operable to be executed by the system to implement the specified measurement task, as described below with reference to
FIG. 10D—System for Executing Tasks
FIG. 11A—Measurement Task Specifier
As
The use of a graphical user interface to guide the user in the specification of a measurement task is to be contrasted with typical prior art methods of task specification in which a user has to manually set values for the many parameters for a desired task. For example, in prior art systems, the user typically has to manually write code, such as C code or LabVIEW code, using a collection of APIs or function calls to set the value of each parameter. In the prior art systems, default values for the parameters are typically not provided, thus the user is expected not only to know all of the channel, timing and triggering parameters required for the task, but the appropriate values for each, as well. Examples of prior art solutions are compared to solutions generated by the methods described herein are presented below with reference to
FIG. 11B—Measurement Task Specification
As shown, in one embodiment, the MSOs which compose the measurement task specification 740 may include one or more channel MSOs 746 and timing/triggering MSOs 748. The channel MSOs 746 may each include one or more parameters for configuring a channel for the measurement task. For example, channel configuration parameters included in a channel MSO 746 may include one or more of: task name, channel name, terminals, input ranges, units, scales, and sensors, among others. The timing/triggering MSOs 748 may each include one or more parameters specifying timing and/or triggering for the measurement task. Examples of timing parameters include scan rate, number of samples, duration, clock type, and clock source, among others. Example triggering parameters include trigger type, source, edge, level, window, and hysterisis, among others. Thus, each MSO may codify (via one or more parameters) a particular aspect or component involved in performing the measurement task.
One example of an MSO corresponds to a measurement. In one embodiment, a ‘measurement MSO’ may comprise a phenomenon (i.e., a detectable signal), a terminal configuration, a desired resolution, a name, and one or more constraints. The particular values of these fields may thus specify a particular measurement. Different measurement specification objects may be linked together to form a measurement task specification.
FIG. 12—Measurement Task Specification Process
As
As
Once the measurement task source program 1208 has been generated, the user may initiate the program, as indicated in by 1210. In an embodiment where the measurement task source program 1208 is a graphical program, e.g., a LabVIEW program, the program initiation 1210 may simply involve the user activating a node, e.g., a “play” or “read/write” node or icon of the graphical program. Further details of the “play” node are presented below with reference to
As
As mentioned above, the measurement task specifier 730 may be implemented in a variety of forms, including a graphical measurement task configuration tool, a wizard, or an API, among others. In a graphical measurement task configuration tool embodiment, the measurement task specifier 730 may comprise a software program invocable by the user under a development environment. The measurement task configuration tool may comprise an interactive Graphical User Interface (GUI) which may provide an intuitive and powerful way for a user to specify a measurement task.
FIG. 13—Measurement Task Configuration Tool Architecture
In one embodiment, the measurement task configuration tool may be implemented in a graphical programming language, such as National Instruments' LabVIEW graphical programming environment. The GUI of the configuration tool may be a Virtual Instrument (VI) accessed by the user to specify and configure measurement tasks.
For example, in one embodiment, the configuration tool (hosted by the Workshops framework) may run stand-alone, launched directly from an ADE, or may be hosted in another application, such as National Instruments' MAX [Measurement & Automation Explorer] program.
In one embodiment, there may be two parts to the plug-in architecture: plugging-in to Workshops, and plugging-in to a configuration tool framework.
Workshop Plug-In Architecture
In one embodiment, the configuration tool may be written entirely in National Instruments' LabVIEW graphical programming language. Hosting a Virtual Instrument (VI) from the Workshops framework may utilize some or all of the following:
1) A Main State VI 1010 that maintains execution, which is preferably not visible to users.
2) A GUI VI through which a user may configure their task.
3) A Block .INI File 1304 specifying the directory paths of the VI's, block names, help file, etc. 1305.
4) A Block Icon 1306 for the GUI application.
In one embodiment, each .INI file specification may automatically appear as a “block” in an “Add” popup palette or menu of the workshops framework (see
In one embodiment, the GUI and/or Workshops framework may support “Undo”, “Redo”, and full-state “Restore” commands by automatically copying appropriate controls from the GUI to the State VI, and then storing/restoring this data. A block VI may be programmed to respond to these events and freely exchange its data to/from the workshop in order to support these features.
Measurement Task Configuration Tool Plug-In Architecture
To maximize extensibility and development ease of use, and to minimize disk footprint, there may be a single Main Template VI 1308 that dynamically displays only the measurement type/phenomenon that is being configured. For example, if a user is configuring a voltage measurement, the VI may only display the configuration components necessary for a voltage measurement (See
In one embodiment, each measurement class component (the piece of the UT that is specific to the measurement type being configured) may be a separate VI, referred to as a Measurement Class VI 1312 that may be dynamically loaded by the main GUI template. A “measurement class” ID may be passed to this VI by the Workshop, which tells it what measurement class component VI to load based on which button was selected from the popup palette. Each Measurement Class VI 1312 may be a small state-model VI used for processing events unique to its own front panel, and may have a number of built-in system events for communication to/from the Main Template VI 1308 for such operations as initialization and data processing. The remainder of events may be user-instantiated events which tell the VI how to act when a user changes a control on the front panel, for example.
FIG. 14—Initial Screen
In one embodiment, upon launch of the measurement task specifier 730 (also referred to as a measurement task configuration tool or task configurator in this embodiment) the graphical user interface (GUI) may present an initial screen to the user.
FIG. 15—Measurement Type Selection
When the user begins the specification process, such as by clicking the “add” button of
In one embodiment, the selection of a measurement type may spawn a sub-menu which may provide additional selection options. For example, as mentioned above, the measurement task may include signal generation, as well as measurements, thus, in one embodiment, in response to the user's selection of the voltage measurement type, the GUI may display a sub-menu or sub-control which presents additional selection options related to voltage, e.g., “voltage input” or “voltage output”, among others. Although a measurements types panel is presented in this embodiment, in other embodiments, other controls may be used, such as pop-up menus and text entry fields, among others.
The selection of the measurement type may establish logical guidelines for subsequent GUI displays. In other words, the information and/or options presented by the GUI to the user may depend upon the measurement type selected. This type of context-dependency may pervade the structure and operation of the measurement task specifier 730, various examples of which are described below.
FIG. 16—Main Configuration Screen
In response to the selection of the measurement type, a main configuration screen may be displayed by the GUI corresponding to the selected measurement type, one embodiment of which is illustrated by
As
Just below the channel selection panel is a timing panel, presented by the GUI for the user to specify timing parameters for the measurement task, such as sampling mode, number of samples, and sample rate. In this example, the timing panel shown is a “basic view” of timing and triggering parameters. An “advanced view”, selectable from the view control shown, is described below with reference to
As mentioned above, the GUI may also display a context sensitive help panel, here shown to the right of the screen. The help panel may display useful information related to the currently displayed configuration panels. For example, if the GUI presents a panel for setting channel parameters, the help panel may present information related to the channel parameters, or instructions for specifying values for the channel parameters. In one embodiment, the GUI may also display an auxiliary display panel, here shown below the help panel with an “under construction” label, which may be used to display auxiliary information of any type, as desired. For example, in one embodiment, the auxiliary display panel may be an error display window whereby error messages and codes may be presented to the user when errors are detected by the system.
FIG. 17—Channel Selection
FIGS. 18A-18B—Channel Configuration
In response to the channel selection described above, the GUI may present one or more channel configuration panels, as
FIG. 19—Channel Configuration: Details
As
Of course, in other embodiments, the parameters presented by the details panel and the setting panel described above with reference to
In another embodiment, the details tab may be a read-only type information tab, with no parameters actually set by the user. This tab would then be for display purposes only, presenting detailed channel information to the user, such as configured device and terminals, for example.
In one embodiment, in addition to configuring tasks that may contain one or more local or global channels, the measurement task specifier may also be operable to configure channels independent of any particular task. These channels are inherently global, as defined above, and, after being configured, can later be inserted into tasks as necessary. In this embodiment, the measurement task specifier may not present any task specific configuration panels to the user, such as the timing, triggering, and device panels, but rather, may present only panels that are used to specify channel properties. Thus, in this embodiment, the generated measurement task specification may contain only channel specific configuration information, which may then be applied to any tasks.
FIG. 20—Channel Configuration: Scaling
FIG. 21—Channel Configuration: Custom Scaling
FIG. 22—Channel Configuration: Pop-up Menu
FIGS. 23A and 23B—Channel Configuration: Pop-up Panels
FIG. 24—Timing: Advanced View
As
FIG. 25—Triggering: Advanced View
FIG. 26—Device Settings
FIG. 27—Code Generation
As mentioned above, in one embodiment, options may be presented to the user for the programmatic generation of an application program for performing the measurement task.
FIGS. 28A-28G—Code Generation Levels
FIG. 28A—Code Generation Level Selection
In this example, two different levels of code generation are presented: 1) basic, where all the code necessary to perform the specified task from the generated measurement task specification 740 is generated and represented by one or more nodes. Examples of basic code generation are shown in
The provision of different levels of code generation may enhance the portability of the final product. For example, the basic level programs may use the measurement task specification 740 stored in a library or other storage means (such as MAX 704) to build a run-time 790. An issue with this level of generated code is that in order to run the program on another machine, not only the diagram or VI (the graphical program) is needed, but also the measurement task specification 740 that is stored (e.g., in MAX). Thus, the generated graphical program is not a complete exportable program. This is a primary reason for the advanced level of code generation. The advanced level program may actually build up the entire measurement task specification 740 “from scratch” on the user's diagram, i.e., the program may build the measurement task specification dynamically from the user-indicated parameters. The purpose of this is to show exactly what it takes to build a low level program. Also, because it builds everything from scratch, the program may easily be deployed to another machine, since it does not rely on the task object (the measurement task specification 740) to be present (in MAX).
In one embodiment, code may be generated at a simpler level than the ‘basic’ level described above. At this level, all code for the measurement task is generated into, or represented by, a single “wizard-locked” node or subVI. The term “wizard-locked” refers to the fact that whereas a typical graphical program node or subVI may be expanded into a sub-diagram, such as by (double) clicking on the node, a wizard-locked node simply invokes the “wizard” (in this case, the configuration tool 730), allowing the user to edit the node specifications or functionality without giving the user visual or direct access to the actual diagram. In other words, the actual graphical code is encapsulated by a single node, and the user does not have access to the contents of the node except through the wizard or configuration tool 730.
FIGS. 28B-28D—Basic Code Generation
It should be noted that the single node, in this case a read node, may encapsulate or encode both the conversion of the measurement task specification 740 into an executable run-time 790, as described above in steps 508 and 510 of
In other words, the graphical program may include a node which is configured to receive the measurement task specification as input, i.e., an input terminal of the node may be connected to an output terminal of another node in the graphical program, e.g., a measurement task specification node, which may provide the measurement task specification to the node as input. Upon execution of the graphical program, the node may receive the measurement task specification as input, invoke an expert system to analyze the measurement task specification and generate a run-time specification for the measurement task in response to the analyzing, as shown in 750 and 770 of
As
FIGS. 28E-28G—Advanced Code Generation
In the advanced code generation programs of
Thus, in one embodiment, the single node described above which receives the measurement task specification may be connected or wired to a configuration node, which may in turn be wired to further configuration nodes, and which operates to configure the measurement task specification for input to the node. This is in contrast to the basic code generation where the single node is wired to the measurement task specification node which represents the already generated measurement task specification 740. Thus, the configuration node(s) may operate to generate the measurement task specification 740 for input to the single node.
For example, in
Finally, the last configuration node, e.g., the triggering configuration node in
Note that in the diagrams of
FIG. 29—Complex Measurement Tasks
In one embodiment, the configuration tool 730 may allow the specification of multiple measurement types in a single measurement task, subject to feasibility. For example, a measurement task may include measuring both temperature and pressure, or temperature and voltage. As another example, in a testing application, the measurement task may include both the generation of a signal for stimulation of a device, and measurement of the voltage response of the device. Thus, the measurement task may include one or more measurements, and/or one or more signal generations.
In one embodiment, the measurement task may include a complex measurement operation using a plurality of measurement devices, where at least one of the measurement devices is a measurement hardware device. In another embodiment, at least one of the plurality of measurement devices may be a virtual measurement device, i.e., a device implemented in software.
Example Virtual Instrument Diagrams
FIGS. 30A-30B—Comparison of Generated Code to Prior Art Code
FIG. 31A—Acquisition of N Scans with External Scan Clock and Digital Trigger (Prior Art)
FIG. 31B—Acquisition of N Scans with External Scan Clock and Digital Trigger
As
FIGS. 32A and 32B—Testing The Configured Task
In one embodiment, the measurement task specifier may provide the ability to test the current configuration settings.
In one embodiment, one or more test panels may be displayed in response to user input, e.g., when the user presses the “run” button. These test panels may be unique to the current measurement type, or, in other embodiments, may be common across multiple measurement types. In one embodiment, as shown by
It should be noted that the examples presented in
It should be noted that various embodiments may further include receiving, sending or storing instructions and/or data implemented in accordance with the foregoing description upon a carrier medium. Generally speaking, a carrier medium may include storage media or memory media such as magnetic or optical media, e.g., disk or CD-ROM, volatile or non-volatile media such as RAM (e.g. SDRAM, DDR SDRAM, RDRAM, SRAM, etc.), ROM, etc. as well as transmission media or signals such as electrical, electromagnetic, or digital signals, conveyed via a communication medium such as network and/or a wireless link.
Although the system and method of the present invention have been described in connection with several embodiments, the invention is not intended to be limited to the specific forms set forth herein, but on the contrary, it is intended to cover such alternatives, modifications, and equivalents as may be reasonably included within the spirit and scope of the invention as defined by the appended claims.
Claims
1. A computer-implemented method, comprising:
- displaying, via a graphical user interface (GUI), a plurality of panels comprising information for guiding a user in specifying parameters for a measurement task to be performed using one or more measurement devices, wherein the information comprises default values for one or more parameters of the measurement task;
- receiving user input via the GUI relating to the measurement task, wherein said receiving user input comprises either overriding or indicating acceptance of a default value displayed for a first parameter of the measurement task;
- generating program instructions usable to implement the measurement task using the one or more measurement devices, wherein said generating is based at least in part upon the user input.
2. The computer-implemented method of claim 1,
- wherein said displaying the plurality of panels comprises displaying a first panel followed by a second panel;
- wherein said receiving user input via the GUI comprises receiving first user input to the first panel;
- the method further comprising automatically generating the default value based on the first user input to the first panel;
- wherein said displaying the plurality of panels further comprises displaying the default value in the second panel after said automatically generating;
- wherein said receiving user input via the GUI comprises receiving second user input to the second panel, wherein the second user input overrides or indicates acceptance of the default value displayed in the second panel.
3. The computer-implemented method of claim 1,
- wherein said displaying comprises displaying a first panel, a second panel, and a third panel, wherein the default value displayed for a first parameter of the measurement task is displayed in the third panel, and wherein said receiving user input via the GUI comprises receiving user input to the first and second panels, and wherein the method further comprises:
- automatically generating the default value based on the user input to the first and second panels.
4. The computer-implemented method of claim 1, wherein said receiving user input comprises receiving first user input specifying the measurement task from among a plurality of measurement tasks.
5. The computer-implemented method of claim 1, wherein the generated program instructions are usable for inclusion in a first program in order to implement the measurement task using the one or more measurement devices.
6. The computer-implemented method of claim 5, wherein the first program is a graphical program.
7. The computer-implemented method of claim 5, wherein the generated program instructions are source code and the first program includes source code.
8. The computer-implemented method of claim 1, wherein the generated program instructions are in executable form.
9. The computer-implemented method of claim 1, wherein the generated program instructions are graphical code, wherein the graphical code comprises a plurality of nodes connected by lines which visually indicates functionality of the graphical code.
10. The computer-implemented method of claim 1, wherein the default value is automatically generated in response to one or more parameter values specified by the user.
11. The computer-implemented method of claim 10, wherein said displaying comprises displaying a first panel that is usable to receive an input value for a second parameter of the measurement task, and wherein said displaying comprises displaying a second panel displayed subsequent to the first panel that is usable to display the default value for the first parameter of the measurement task, wherein the default value for the first parameter is automatically generated using the input value previously received for the second parameter.
12. The computer-implemented method of claim 1, wherein the default value for the first parameter is a numeric value.
13. A computer-readable memory medium storing first program instructions that are computer executable to:
- display, via a graphical user interface (GUI), a plurality of panels comprising information for guiding a user in specifying parameters for a measurement task to be performed using one or more measurement devices, wherein the information comprises one or more default values for one or more parameters of the measurement task;
- receive user input via the GUI relating to the measurement task, wherein said receiving user input comprises either overriding or indicating acceptance of a default value displayed for a first parameter of the measurement task;
- generate, based at least in part upon the user input, second program instructions usable to implement the measurement task on the one or more measurement devices.
14. The computer-readable memory medium of claim 13,
- wherein said displaying the plurality of panels comprises displaying a first panel followed by a second panel;
- wherein said receiving user input via the GUI comprises receiving first user input to the first panel;
- wherein the first program instructions are further executable to automatically generate the default value based on the first user input to the first panel;
- wherein said displaying the plurality of panels further comprises displaying the default value in the second panel after said automatically generating;
- wherein said receiving user input via the GUI comprises receiving second user input to the second panel, wherein the second user input overrides or indicates acceptance of the default value displayed in the second panel.
15. The computer-readable memory medium of claim 13, wherein said displaying comprises displaying a first panel, a second panel, and a third panel, wherein said displaying comprises displaying the default value in the third panel, and wherein said receiving user input via the GUI comprises receiving user input to the first and second panels, and wherein the first program instructions are further executable to:
- automatically generate the default value based on the user input to the first and second panels.
16. The computer-readable memory medium of claim 13, wherein the generated second program instructions are in executable form.
17. The computer-readable memory medium of claim 13, wherein the generated second program instructions are source code.
18. The computer-readable memory medium of claim 13, wherein said receiving user input comprises receiving first user input specifying the measurement task from among a plurality of measurement tasks.
19. The computer-readable memory medium of claim 13, wherein the generated second program instructions are usable to include in a first program in order to implement the measurement task using the one or more measurement devices.
20. The computer-readable memory medium of claim 19, wherein the first program is a graphical program.
21. The computer-readable memory medium of claim 19, wherein the generated second program instructions are source code and said first program includes source code.
22. The computer-readable memory medium of claim 19, wherein the generated second program instructions are graphical code, wherein the graphical code comprises a plurality of nodes connected by lines which visually indicates functionality of the graphical code.
23. The computer-readable memory medium of claim 13, wherein one or more of the default values are automatically generated in response to one or more parameter values specified by said user.
24. The computer-readable memory medium of claim 23, wherein said displaying comprises displaying a first panel that is usable to receive an input value for a second parameter of the measurement task, and wherein said displaying further comprises displaying a second GUI panel displayed subsequent to the first panel that is usable to display the default value for the first parameter of the measurement task, wherein the first program instructions are executable to automatically generate the default value for the first parameter using the input value previously received for the second parameter.
25. The computer-readable memory medium of claim 13, wherein the default value for the first parameter is a numeric value.
26. A computer system, comprising:
- an input device;
- a display;
- a processor subsystem;
- a memory subsystem storing first program instructions that are executable by the processor subsystem to: display, via a graphical user interface (GUI) on the display, a plurality of panels comprising information for guiding a user in specifying parameters for a measurement task to be performed using one or more measurement devices, wherein the information comprises one or more default values for one or more parameters of the measurement task; receive user input via the GUI relating to the measurement task, wherein said receiving user input comprises either overriding or indicating acceptance of a default value displayed for a first parameter of the measurement task; generate second program instructions usable to implement the measurement task using the one or more measurement devices, wherein said generating is based at least in part upon the user input.
27. The computer system of claim 26,
- wherein in said displaying the plurality of panels the first program instructions are executable to display a first panel followed by a second panel;
- wherein in said receiving user input via the GUI the first program instructions are executable to receive first user input to the first panel;
- wherein the first program instructions are further executable to automatically generate the default value based on the first user input to the first panel;
- wherein in said displaying the plurality of panels the first program instructions are executable to display the default value in the second panel after the default value is automatically generated;
- wherein in said receiving user input via the GUI the first program instructions are executable to receive second user input to the second panel, wherein the second user input overrides or indicates acceptance of the default value displayed in the second panel.
28. The computer system of claim 26,
- wherein in said displaying the first program instructions are executable to display a first panel, a second panel, and a third panel, wherein the default value is displayed in the third panel, and wherein user input received via the GUI comprises user input to the first and second panels; and
- wherein the first program instructions are further executable to automatically generate the default value based on the user input to the first and second panels.
29. The computer system of claim 26, wherein the generated program instructions are in executable form.
30. The computer system of claim 26, wherein the generated program instructions are source code.
31. The computer system of claim 30, wherein the generated program instructions are usable to include in a first program in order to implement the measurement task using the one or more measurement devices.
32. The computer system of claim 31, wherein the first program is a graphical program.
33. The computer system of claim 26, wherein the generated program instructions are graphical code, wherein the graphical code comprises a plurality of nodes connected by lines which visually indicates functionality of the graphical code.
34. The computer system of claim 26, wherein one or more of said default values are automatically generated in response to one or more parameter values previously specified by the user.
35. A computer-implemented method, comprising:
- displaying, via a graphical user interface (GUI), a plurality of panels comprising information for guiding a user in specifying parameters for a measurement task to be performed using one or more measurement devices, wherein the plurality of panels comprise a first panel and a second panel;
- receiving user input via the GUI relating to the measurement task, wherein said receiving user input comprises receiving first user input to the first panel, wherein the first user input specifies a measurement type, wherein said receiving user input comprises receiving second user input to the second panel, wherein the second user input specifies the one or more measurement devices for the measurement task;
- generating program instructions usable to implement the measurement task using the one or more measurement devices, wherein said generating is based at least in part upon the user input.
36. The computer-implemented method of claim 35, wherein said displaying comprises displaying default values for one or more parameters of the measurement task in the plurality of panels.
37. The computer-implemented method of claim 36, wherein said displaying default values for the one or more parameters comprises displaying a default value for the one or more measurement devices for the measurement task, and wherein the method further comprises:
- automatically determining the default value for the one or more measurement devices based on the first user input.
38. The computer-implemented method of claim 36, wherein said receiving user input comprises either overriding or indicating acceptance of a default value displayed for a first parameter of the measurement task.
39. The computer-implemented method of claim 35, wherein said receiving user input comprises receiving third user input specifying a channel of the one or more measurement devices.
40. The computer-implemented method of claim 35, wherein the measurement type comprises one or more of signal generation, voltage, current, pressure, acceleration, frequency, resistance, strain, or temperature.
41. The computer-implemented method of claim 35, wherein the measurement type comprises one or more of analog or digital.
42. The computer-implemented method of claim 35, wherein the measurement type comprises one or more of analog input, analog output, digital input, or digital output.
43. The computer-implemented method of claim 35, wherein the one or more measurement devices comprises a data acquisition device.
44. A computer-implemented method, comprising:
- displaying, via a graphical user interface (GUI), a plurality of panels comprising information for guiding a user in specifying parameters for a measurement task to be performed using one or more measurement devices, wherein the plurality of panels comprise a first panel and a second panel;
- receiving user input via the GUI relating to the measurement task, wherein said receiving user input comprises receiving first user input to the first panel, wherein the first user input specifies the one or more measurement devices for the measurement task, wherein said receiving user input comprises receiving second user input to the second panel, wherein the second user input specifies a channel of the one or more measurement devices;
- generating program instructions usable to implement the measurement task using the one or more measurement devices, wherein said generating is based at least in part upon the user input.
45. The computer-implemented method of claim 44, wherein said displaying comprises displaying default values for one or more parameters of the measurement task in the plurality of panels.
46. The computer-implemented method of claim 45, wherein said displaying default values for the one or more parameters comprises displaying a default value for the channel of the one or more measurement devices, and wherein the method further comprises:
- automatically determining the default value for the channel based on the first user input.
47. The computer-implemented method of claim 45, wherein said receiving user input comprises either overriding or indicating acceptance of a default value displayed for a first parameter of the measurement task.
48. The computer-implemented method of claim 44, wherein said receiving user input comprises receiving third user input specifying timing information of the measurement task.
49. The computer-implemented method of claim 44, wherein said receiving user input comprises receiving third user input specifying triggering information of the measurement task.
50. The computer-implemented method of claim 44, wherein the one or more measurement devices comprise a data acquisition device.
51. A computer-implemented method, comprising:
- displaying, via a graphical user interface (GUI), a plurality of panels comprising information for guiding a user in specifying parameters for a measurement task to be performed using one or more measurement devices, wherein the plurality of panels comprise a first panel and a second panel;
- receiving user input via the GUI relating to the measurement task, wherein said receiving user input comprises receiving first user input to the first panel, wherein the first user input specifies timing information for the measurement task, wherein said receiving user input comprises receiving second user input to the second panel, wherein the second user input specifies triggering information for the measurement task;
- generating program instructions usable to implement the measurement task using the one or more measurement devices, wherein said generating is based at least in part upon the user input.
52. The computer-implemented method of claim 51, wherein said displaying comprises displaying default values for one or more parameters of the measurement task in the plurality of panels.
53. The computer-implemented method of claim 52, wherein said displaying default values for the one or more parameters comprises displaying a default value for the triggering information of the one or more measurement devices, and wherein the method further comprises:
- automatically determining the default value for the triggering information based on the first user input.
54. The computer-implemented method of claim 52, wherein said receiving user input comprises either overriding or indicating acceptance of a default value displayed for a first parameter of the measurement task.
4812996 | March 14, 1989 | Stubbs |
4868785 | September 19, 1989 | Jordan et al. |
4884228 | November 28, 1989 | Stanley et al. |
5133045 | July 21, 1992 | Gaither et al. |
5136705 | August 4, 1992 | Stubbs et al. |
5155836 | October 13, 1992 | Jordan et al. |
5481741 | January 2, 1996 | McKaskle et al. |
5630164 | May 13, 1997 | Williams et al. |
5764546 | June 9, 1998 | Bryant et al. |
5812394 | September 22, 1998 | Lewis et al. |
5821934 | October 13, 1998 | Kodosky et al. |
5926775 | July 20, 1999 | Brumley et al. |
5991537 | November 23, 1999 | McKeon et al. |
6047219 | April 4, 2000 | Eidson |
6067584 | May 23, 2000 | Hayles et al. |
6096094 | August 1, 2000 | Kay et al. |
6098028 | August 1, 2000 | Zwan et al. |
6128759 | October 3, 2000 | Hansen |
6134674 | October 17, 2000 | Akasheh |
6173438 | January 9, 2001 | Kodosky et al. |
6219628 | April 17, 2001 | Kodosky et al. |
6320577 | November 20, 2001 | Alexander |
6418391 | July 9, 2002 | Umezu et al. |
6647513 | November 11, 2003 | Hekmatpour |
6879926 | April 12, 2005 | Schmit et al. |
6885829 | April 26, 2005 | Braun et al. |
20020030683 | March 14, 2002 | Alexander |
20030163298 | August 28, 2003 | Odom et al. |
0 710 910 | May 1996 | EP |
01/59406 | August 2001 | WO |
- National Instruments “The Measurement and Automation Catalog 2001”, Copyright 2000, pp. 252-255.
- International Search Report, Application No. PCT/US03/13010, mailed Sep. 4, 2003.
- Microsoft Press Computer Dictionary, 1994, p. 185.
Type: Grant
Filed: Dec 1, 2006
Date of Patent: Mar 3, 2009
Patent Publication Number: 20070156366
Assignee: National Instruments Corporation (Austin, TX)
Inventors: Brian Johnson (Austin, TX), John Breyer (Austin, TX), Joseph Albert Savage (Cedar Park, TX)
Primary Examiner: Hal D Wachsman
Attorney: Meyertons Hood Kivlin Kowert & Goetzel, P.C.
Application Number: 11/566,107
International Classification: G06F 17/40 (20060101); G06F 11/00 (20060101);