METHODS AND APPARATUS TO CONFIGURE A PROCESS CONTROL SYSTEM USING AN ELECTRONIC DESCRIPTION LANGUAGE SCRIPT

Abstract
Example methods and apparatus to configure a process control system using an electronic description language (EDL) script are disclosed. A disclosed example method comprises loading a first script representative of a process plant, the first script comprising an interpretive system-level script structured in accordance with an electronic description language, and compiling the first script to form a second script, the second script structured in accordance with a vendor-specific configuration language associated with a particular process control system for the process plant.
Description
FIELD OF THE DISCLOSURE

This disclosure relates generally to process control systems and, more particularly, to methods and apparatus to configure a process control system using an electronic description language (EDL) script.


BACKGROUND

Electronic device description languages (EDDLs) have been used to provide a structured and standardized format to describe and specify field devices of process plants to facilitate interpretation, control and/or management of the field devices by the control components of a host process control system. As such, EDDLs typically incorporate standardized interfaces for parameterization and visualization of data associated with the field devices. More recently, EDDLs have been enhanced to describe and/or specify advanced displays and/or graphical representations of field device data.


SUMMARY

A disclosed example method includes loading a first script representative of a process plant, the first script comprising an interpretive system-level script structured in accordance with an electronic description language, and compiling the first script to form a second script, the second script structured in accordance with a vendor-specific configuration language associated with a particular process control system for the process plant.


A disclosed example apparatus includes an editor useable to create a first script representative of a process plant, the first script comprising an interpretable system-level script structured in accordance with an electronic description language, and a compiler to form a second script from the first script, the second script structured in accordance with a vendor-specific configuration language associated with a particular process control system for the process plant.


Another disclosed example method includes utilizing an editor to form a first script representative of a process plant, the first script comprising an interpretive system-level script structured in accordance with an electronic description language, generating a second script from the first script, the second script structured in accordance with a configuration language for a particular process control system, and configuring the process control system for the process plant based on the second script.





BRIEF DESCRIPTION OF THE DRAWINGS


FIG. 1 is a schematic illustration of an example process control system constructed in accordance with the teachings of this disclosure.



FIG. 2 illustrates an example manner of implementing the example process plant configuration system of FIG. 1.



FIG. 3 illustrates an example manner of implementing the example compiler of FIG. 2.



FIG. 4 illustrates an example schema that may be used to graphically represent the example process control system of FIG. 1.



FIG. 5 illustrates an example system-level EDL script that may be used to represent the example schema of FIG. 4.



FIGS. 6-9 illustrate example schema elements that may be used to form a schema for a process control system.



FIG. 10 illustrates an example system-level EDL script constructed from the example schema elements of FIGS. 8 and 9.



FIG. 11 is a flowchart representative of an example process that may be used to configure the example process control system of FIG. 1 based on a system-level EDL script.



FIG. 12 is a flowchart representative of an example process that may be used to convert a system-level EDL script into a process control system specific configuration script.



FIG. 13 is a schematic illustration of an example processor platform that may be used and/or programmed to carry out the example processes of FIGS. 11 and/or 12 and/or, more generally, to implement the example process plant configuration system of FIGS. 1 and 2.





DETAILED DESCRIPTION

In general, the example apparatus, methods, and articles of manufacture described herein may be used to define, describe and/or otherwise specify all or any portion(s) of a process plant control system via an electronic description language (EDL) script and/or an interpretative system-level script. In some EDL script languages, such as those constructed in accordance with an extensible markup language (XML), such EDL scripts are also referred to as schemas. Previously, electronic device description languages (EDDLs) and EDL scripts were only used to define, describe and/or otherwise specify the field devices of a process control system. In contrast, the example EDL scripts described herein are useable to define, describe and/or otherwise specify any number and/or type(s) of additional and/or alternative control and/or non-control components of the process control system. Moreover, the example EDL scripts are useable to define, describe and/or specify any number and/or type(s) of interconnections between any or all components of the process control system. Thus, in some examples, a single schema can be used to define the entirety of a process control system. Example components of a process control system that have not previously been defined via an EDL script include, but are not limited to, a controller, an operator workstation, an input/output (I/O) card, a router, a switch, a hub, a firewall, a power supply, and/or an I/O gateway.


The example EDL scripts described herein are constructed to support process control system components manufactured, provided and/or implemented by any process control system vendor. Accordingly, as described more fully below in connection with FIG. 3, such EDL scripts can subsequently be compiled, translated, interpreted and/or otherwise processed to form one or more vendor-specific and/or system-specific scripts that may then be loaded into and/or otherwise used to configure particular process control system components from any number of particular component vendors. As such, such vendor and/or system-specific scripts are generally structured in accordance with a vendor-specific configuration language.



FIG. 1 is a schematic illustration of an example process control system 100. In the interest of brevity and clarity, throughout the following disclosure references will be made to the example process control system 100 of FIG. 1. However, the methods and apparatus described herein to define, specify, describe and/or configure a process control system based on EDL scripts are applicable to other process control systems. The example process control system 100 of FIG. 1 includes one or more process controllers (one of which is designated at reference numeral 110), one or more operator stations (one of which is designated at reference numeral 115), and one or more workstations (one of which are designated at reference numeral 120). The example process controller 110, the example operator station 115 and the workstation 120 are communicatively coupled via a bus and/or local area network (LAN) 125, which is commonly referred to as an application control network (ACN).


The example operator station 115 of FIG. 1 allows a process plant operator to review and/or operate one or more operator display screens and/or applications that enable the process plant operator to view process plant variables, view process plant states, view process plant conditions, view process plant alarms, and/or to change process plant settings (e.g., set points and/or operating states, clear alarms, silence alarms, etc.). Such screens and/or applications are typically designed and/or implemented by process configuration engineers.


The example workstation 120 of FIG. 1 may be configured as an application station to perform one or more information technology applications, user-interactive applications and/or communication applications. For example, the workstation 120 may be configured to perform primarily process control-related applications, while another application station (not shown) may be configured to perform primarily communication applications that enable the process control system 100 to communicate with other devices or systems using any desired communication media (e.g., wireless, hardwired, etc.) and protocols (e.g., HTTP, SOAP, etc.). The example operator station 115 and the example workstation 120 of FIG. 1 may be implemented using one or more workstations and/or any other suitable computer systems and/or processing systems. The operator station 115 and/or workstation 120 could, for example, be implemented using single processor personal computers, single or multi-processor workstations, etc.


The example LAN 125 of FIG. 1 may be implemented using any desired communication medium and protocol. For example, the LAN 125 may be based on a wired and/or wireless Ethernet communication scheme. However, as will be readily appreciated by those having ordinary skill in the art, any other suitable communication medium(s) and/or protocol(s) could be used. Further, although a single LAN 125 is illustrated in FIG. 1, more than one LAN and/or other alternative pieces of communication hardware may be used to provide redundant communication paths within the example system 100 of FIG. 1.


The example controller 110 of FIG. 1 is coupled to a plurality of smart field devices 130, 131 and 132 via a digital data bus 135 and an input/output (I/O) gateway 140. The smart field devices 130-132 may be Fieldbus compliant valves, actuators, sensors, etc., in which case, the smart field devices 130-132 communicate via the digital data bus 135 using the well-known Foundation Fieldbus protocol. Of course, other types of smart field devices and communication protocols could be used instead. For example, the smart field devices 130-132 could instead be Profibus and/or HART compliant devices that communicate via the data bus 135 using the well-known Profibus and HART communication protocols. Additional I/O devices, which are different, similar and/or identical to the I/O gateway 140, may be coupled to the controller 110 to enable additional groups of smart field devices, which may be Foundation Fieldbus devices, HART devices, etc., to communicate with the controller 110.


In addition to the example smart field devices 130-132, one or more non-smart field devices 133 and 134 may be communicatively coupled to the example controller 110. The example non-smart field devices 133 and 134 of FIG. 1 may be, for example, conventional 4-20 milliamp (mA) or 0-10 volts direct current (VDC) devices that communicate with the controller 110 via respective links.


The example controller 110 of FIG. 1 may be, for example, a DeltaV™ controller sold by Fisher-Rosemount Systems, Inc., an Emerson Process Management company. However, any other controller could be used instead. Further, while only one controller 110 is shown in FIG. 1, additional controllers and/or process control platforms of any desired type and/or combination of types could be coupled to the LAN 125. In any case, the example controller 110 performs one or more process control routines associated with the process control system 100 that have been generated by a system engineer and/or other system operator using the operator station 115 and which have been downloaded to and/or instantiated in the controller 110.


To configure the control components of the example process control system 100 (for example, the example controller 110, the example operator station 115, the example workstation 120, the example I/O gateway 140 and/or the example field devices 130-134) based on one or more EDL scripts, the example process control system 100 of FIG. 1 includes a process control system configuration system 150. As described below in connection with FIG. 2, the example process control system configuration system 150 of FIG. 1 includes an editor 210 (FIG. 2) to allow a user to create an EDL and/or interpretative script and/or schema that represents in a vendor and/or system non-specific manner possibly all of the process control system 100, and a compiler 220 to generate vendor and/or system specific configuration and/or operation databases based on the EDL script and/or schema. The vendor-specific configuration and/or operation database include one or more vendor-specific scripts, information and/or data that can be used to actually configure specific makes and models of control components of the example process control system 100 and/or are structured in accordance with a vendor-specific configuration language.


While FIG. 1 illustrates an example process control system 100 within which the example apparatus, methods, and articles of manufacture to define, describe and/or otherwise specify all or any portion(s) of a process plant control system via an EDL script described in greater detail below may be advantageously employed, persons of ordinary skill in the art will readily appreciate that the apparatus, methods, and articles of manufacture described herein may, if desired, be advantageously employed in other process plants and/or process control systems of greater or less complexity (e.g., having more than one controller, across more than one geographic location, etc.) than the illustrated example of FIG. 1. Moreover, while not shown in FIG. 1 for clarity of illustration, there may be any number and/or type(s) of additional and/or alternative devices, components and/or systems included in a process plant and/or a process control system. For example, a process plant and/or a process control system may include and/or implement a firewall, a switch, a router, a hub, a power supply, and/or any other devices managed and/or controllable by a process control system, such as the DeltaV process control system sold by Fisher-Rosemount Systems, Inc., an Emerson Process Management company.



FIG. 2 illustrates an example manner of implementing the example process control system configuration system 150 of FIG. 1. To allow a user to create an EDL script and/or schema 205 that represents a process control system, such as the example system 100 of FIG. 1, the example configuration system 150 of FIG. 2 includes any number and/or type(s) of EDL editors, one of which is designated at reference numeral 210, and an EDL library 215. An example schema and EDL script 205 that may be used to represent the example process control system 100 of FIG. 1 are shown below in connection with FIGS. 4 and 5, respectively. The example EDL library 215 of FIG. 1 contains a plurality of EDL-based schemas and/or descriptions for any number and/or type(s) of process control system components and/or process control system interconnections that may be selected and/or used to construct the example EDL script 205. Example schemas for some example process control system components that may be included in the example EDL library 215 are shown below in FIGS. 5-9. A portion of another example EDL script 205 that can be created from the example schema elements of FIGS. 8 and 9 is shown in FIG. 10.


The example EDL editor 210 may be configured to create, modify, view and/or edit XML-based schemas and/or EDL scripts 205 and may, for example, be implemented using XMLSpy® from Altova®. However, any EDL editor 210 may be used instead. Utilizing one or more user interfaces and/or menus of the example EDL editor 210, a user interacts with the example EDL editor 210 of FIG. 2 to create the example EDL script 205. For example, the user may interact with the EDL editor 210 to select, connect and/or configure schema elements from the EDL library 215 to form a vendor and/or system independent representation of (that is, a schema for) the example process control system 100 of FIG. 1.


To compile the example EDL-script 205, the example process control system configuration system 150 of FIG. 2 includes the example compiler 220. The example compiler 220 of FIG. 2 generates and/or forms the vendor-specific control system configuration scripts, files and/or data 225 based on the vendor non-specific EDL script 205. The example compiler 220 may generate the vendor-specific information 225 by compiling, translating and/or otherwise processing the EDL script 205. An example manner of implementing the example compiler 220 of FIG. 2 is described below in connection with FIG. 3.


While forming the system-specific configuration information 225, the example compiler 220 of FIG. 2 may access and/or query a device database 230 for device-specific information and/or data. The example device database 230 of FIG. 2 contains information regarding the interfaces and/or methods implemented by specific control system components. For example, the EDL script 205 may include a reference to a generic I/O gateway. When that generic I/O gateway reference is processed by the example compiler 220, the compiler 220 obtains data and/or information from the device database 230 that is specific to the make and model of the I/O gateway 140 included in the example process control system 100, and includes and/or incorporates such data and/or information in the system-specific configuration script(s) 225.


As shown in FIG. 2, the example device database 230 is implemented in connection with a vendor-specific configuration system 240. The example system specific configuration system 240 of FIG. 2 is a part of the DeltaV process control system sold by Fisher-Rosemount Systems, Inc., an Emerson Process Management company. To allow the example process control system configuration script(s) and/or information 225 to be imported, the example DeltaV configuration system 240 of FIG. 2 includes a database server 245 having an import and/or database population module 250. The example import module 250 of FIG. 2 imports data, files and/or other configuration information from the example system specific script(s) 225 and stores the imported data, files and/or configuration information in a DeltaV configuration database 255. As configured via, for example, one or more configuration tools 260, the example database server 245 of FIG. 2 creates a DeltaV operation database 265 based on and/or from data, files and/or other configuration information stored in the DeltaV configuration database 255. The actual (i.e., physical) process control components of the process control system 100 are loaded, configured and/or programmed based on the thus formed example DeltaV operation database 265. While the example system-specific configuration script(s) 225 of FIG. 2 are generated by the example compiler 220, any portion of the system-specific configuration script(s) 225 may, additionally or alternatively, be generated using other tools and/or interfaces (not shown) of, for example, the DeltaV process control system.


While an example manner of implementing the example process control system configuration system 150 of FIG. 1 has been illustrated in FIG. 2, one or more of the interfaces, data structures, elements, processes and/or devices illustrated in FIG. 2 may be combined, divided, re-arranged, omitted, eliminated and/or implemented in any other way. For example, the configuration system 240 may include configuration system modules specific to any number of additional and/or alternative process control systems from other vendors. Further, the example EDL editor 210, the example EDL script 205, the example EDL library 215, the example compiler 220, the example system-specific script(s) 225, the example device database 230, the example DeltaV configuration system 240, the example database server 245, the example import module 250, the example DeltaV configuration database, the example configuration tools 260, the example DeltaV operation database 265 and/or, more generally, the example process control system configuration system 150 of FIG. 2 may be implemented by hardware, software, firmware and/or any combination of hardware, software and/or firmware. Thus, for example, any or the example EDL editor 210, the example EDL script 205, the example EDL library 215, the example compiler 220, the example system-specific script(s) 225, the example device database 230, the example DeltaV configuration system 240, the example database server 245, the example import module 250, the example DeltaV configuration database, the example configuration tools 260, the example DeltaV operation database 265 and/or, more generally, the example process control system configuration system 150 may be implemented by one or more circuit(s), programmable processor(s), application specific integrated circuit(s) (ASIC(s)), programmable logic device(s) (PLD(s)) and/or field programmable logic device(s) (FPLD(s)), etc. Further still, the process control system configuration system 150 may include interfaces, data structures, elements, processes and/or devices instead of, or in addition to, those illustrated in FIG. 2 and/or may include more than one of any or all of the illustrated interfaces, data structures, elements, processes and/or devices.



FIG. 3 illustrates an example manner of implementing the example compiler 220 of FIG. 2. To identify categorized blocks of text (that is, tokens) within the EDL script 205, the example compiler 220 of FIG. 3 includes a scanner 305 and a tokenizer 310. Using any number and/or type(s) of algorithm(s), logic and/or method(s), the example scanner 305 of FIG. 3 scans and/or parses the EDL script 205 to identify the lexemes within the EDL script 205, that is, to identify particular types of strings of characters contained in the EDL script 205. Example lexemes include, but are not limited to, a string of letters, a string of numbers, a punctuation mark, a mathematical operator, etc. Using any number and/or type(s) of algorithm(s), logic and/or method(s), the example tokenizer 310 of FIG. 3 processes the lexemes identified by the scanner 305 to identify particular tokens, that is, classifiable strings of input characters. For example, the scanner 305 may identify a string-of-letters lexeme representing, for example, a sentence, which the example tokenizer 310 demarcates and/or separates into one or more words. Each token identified by the tokenizer 310 has both a value (e.g., the actual name of a variable) and a type (e.g., a variable, an operator, a number, etc.).


To perform syntactic analysis, the example compiler 220 of FIG. 3 includes a parser 315. Using any number and/or type(s) of algorithm(s), logic and/or method(s), the example parser 315 of FIG. 3 processes and/or analyzes the tokens identified by the example tokenizer 310 to identify and/or determine their relationship(s) with respect to the grammar of the EDL script 205. In other words, the example parser 315 identifies the expressions contained within the EDL script 205.


To translate the expressions identified by the example parser 315 into a vendor and/or system specific form, the example compiler 220 of FIG. 3 includes an interpreter 320. Using any number and/or type(s) of algorithm(s), logic and/or method(s), the example interpreter 320 of FIG. 3 translates each identified expression of the EDL script 205 into a corresponding vendor-specific expression that represents a corresponding action for a particular make and model of control system component. For example, the EDL script 205 may contain an expression assigning a value to an upper limit threshold of a generic temperature gauge. Thus, the interpreter 320 generates one or more corresponding vendor-specific expressions and/or configuration statements 225 that correctly configure the upper temperature limit for a particular make and model of temperature gauge implemented within the process control system 100. In such an example, the example interpreter 320 can obtain the vendor-specific configuration language expressions to correctly configure that make and model of temperature gauge from the device database 230.


While an example manner of implementing the example compiler 220 of FIG. 2 has been illustrated in FIG. 3, one or more of the interfaces, data structures, elements, processes and/or devices illustrated in FIG. 3 may be combined, divided, re-arranged, omitted, eliminated and/or implemented in any other way. Further, the example scanner 305, the example tokenizer 310, the example parser 315, the example interpreter 320 and/or, more generally, the example compiler 220 of FIG. 3 may be implemented by hardware, software, firmware and/or any combination of hardware, software and/or firmware. Thus, for example, any or the example scanner 305, the example tokenizer 310, the example parser 315, the example interpreter 320 and/or, more generally, the example compiler 220 may be implemented by one or more circuit(s), programmable processor(s), ASIC(s), PLD(s) and/or FPLD(s), etc. Further still, the compiler 220 may include interfaces, data structures, elements, processes and/or devices instead of, or in addition to, those illustrated in FIG. 3 and/or may include more than one of any or all of the illustrated interfaces, data structures, elements, processes and/or devices.



FIG. 4 illustrates an example schema 400 that may be used to graphically represent the example process control system 100 of FIG. 1. As shown in FIG. 4, the example process control system 100 includes the example workstation 120 and the example process controller 110 of FIG. 1. The example controller 110 of FIG. 4 has a set of attributes 405 that includes, among other things, a name 406 and a description 407. The example controller 110 of FIG. 4 also has a set of capabilities 410, which are defined and/or specified as a set of attributes 415, and any number and/or type(s) of additional properties 420. For example, the controller 110 may include: (a) one or more interface cards 425 that allow the controller 110 to communicate with other components of the example process control system 100 (for example, any of the example field devices 130-134 and/or the example I/O gateway 140 of FIG. 1), (b) commands 430 that define and/or permit the execution of operations, such as calibration, self-diagnosis, etc., and/or (c) menus 435 may be used to implement a first-level interface structure without having to use a specialized programming language. The example commands 430 of FIG. 4 could be defined such that the commands are automatically inserted into the menu structure 435 of the corresponding component. The example menus 435 of FIG. 4 may be used to allow a user to access basic operations of the corresponding element, such as configuration, run-time operation and/or diagnostics. While only a portion of the example process control system 100 is depicted in FIG. 4, persons of ordinary skill in the art will readily appreciate that all or any portion of a process control system can be depicted via a schema diagram in a manner similar to that shown in FIG. 4.



FIG. 5 illustrates an example EDL script 500 that may be used to represent the example schema 400 of FIG. 4 and, thus, to implement the example EDL script 205 of FIG. 2. The example EDL script 500 of FIG. 5 is constructed in accordance with XML. The process control system 100 of the example EDL script 500 of FIG. 5 references the controller 110 and the workstation 120 via corresponding XML expressions. Likewise, the controller 110 references the example capabilities 410 of FIG. 4. While only a portion of the example schema 400 of FIG. 4 is depicted in the example EDL script 500 of FIG. 5, persons of ordinary skill in the art will readily appreciate that all or any portion of a process control system schema and, thus, a process control system can be expressed in an EDL script in a manner similar to that shown in FIG. 5.



FIGS. 6-9 illustrate some example graphical schema elements that may be used and/or combined to depict and/or define a process control system. The example schema elements of FIGS. 6-9 may be included in a plurality of schemas stored in and/or accessible from the example EDL library 215 of FIG. 2. The example schema element of FIG. 6 depicts a process control system 100 including the controller 110 and the workstation 120. The example schema element of FIG. 7 depicts the process controller 110 having the attributes 415, the capabilities 410, other properties 420, cards 425, commands 430 and menus 435. The illustrated example of FIG. 4 is an example combination of the example schema elements of FIGS. 6 and 7.



FIG. 8 illustrates an example schema that may be used to depict and/or define an interface card 805 to be assigned to and/or linked to, for example, a card 425 of the example controller schema of FIG. 7. The example schema of FIG. 9 depicts and/or defines an I/O channel 905 that may be assigned to and/or linked to, for example, an I/O channel 810 of the example interface card 805 of FIG. 8.



FIG. 10 illustrates a portion of an example EDL script that represents a combination of the example schema elements of FIGS. 8 and 9. In the illustrated example of FIG. 10, the example I/O channel 905 of FIG. 9 is linked to the I/O channel 810 of the example interface card 805 of FIG. 8, as depicted with line 1005.



FIG. 11 illustrates a flowchart representative of an example process that may be carried out to configure the example process control system 100 based on an EDL schema and/or script. FIG. 12 illustrates a flowchart representative of an example process that may be carried out to implement the example compiler 220 of FIGS. 2 and 3. The example processes of FIGS. 11 and 12 may be carried out by a processor, a controller and/or any other suitable processing device. For example, the example processes of FIGS. 11 and 12 may be embodied in coded instructions stored on any tangible computer-readable medium such as a flash memory, a compact disc (CD), a digital versatile disc (DVD), a floppy disk, a read-only memory (ROM), a random-access memory (RAM), a programmable ROM (PROM), an electronically-programmable ROM (EPROM), and/or an electronically-erasable PROM (EEPROM), an optical storage disk, an optical storage device, magnetic storage disk, a magnetic storage device, and/or any other medium which can be used to carry or store program code and/or instructions in the form of machine-accessible instructions or data structures, and which can be accessed by a processor, a general-purpose or special-purpose computer, or other machine with a processor (e.g., the example processor platform P100 discussed below in connection with FIG. 13). Combinations of the above are also included within the scope of computer-readable media. Machine-accessible instructions comprise, for example, instructions and/or data that cause a processor, a general-purpose computer, special-purpose computer, or a special-purpose processing machine to implement one or more particular processes. Alternatively, some or all of the example processes of FIGS. 11 and 12 may be implemented using any combination(s) of ASIC(s), PLD(s), FPLD(s), discrete logic, hardware, firmware, etc. Also, some or all of the example processes of FIGS. 11 and 12 may instead be implemented manually or as any combination of any of the foregoing techniques, for example, any combination of firmware, software, discrete logic and/or hardware. Further, many other methods of implementing the example operations of FIGS. 11 and 12 may be employed. For example, the order of execution of the blocks may be changed, and/or one or more of the blocks described may be changed, eliminated, sub-divided, or combined. Additionally, any or all of the example processes of FIGS. 11 and 12 may be carried out sequentially and/or carried out in parallel by, for example, separate processing threads, processors, devices, discrete logic, circuits, etc.


The example process of FIG. 11 begins with the use of the example EDL editor 210 to create and/or generate of a schema and/or an EDL script 205, such as the example schema 400 of FIG. 4 and/or the example EDL script 500 of FIG. 5, for the example process control system 100 (block 1105). The example compiler 220 is executed and/or operated to create a system and/or vendor-specific data and/or configuration information 225 from the EDL script 205 (block 1110).


Using the example import and/or database population module 250, the system and/or vendor-specific data and/or configuration information 225 is imported into the system and/or vendor-specific configuration database 255 (block 1115). The example database server 245 is operated and/or executed to form the system and/or vendor-specific operation database 265 based on the configuration database 255 (block 1120). The process control system 100 is configured, loaded and/or programmed from the operation database 265 (block 1125). Control then exits from the example process of FIG. 11.


The example process of FIG. 12 begins with the example scanner 305 of FIG. 3 scanning the EDL script file 205 to identify the lexemes contained in the EDL script file 205 (block 1205). The example tokenizer 310 identifies tokens contained in the EDL script file 205 based on the identified lexemes (block 1210).


Based on the tokens identified by the tokenizer 310, the example parser 315 of FIG. 3 analyzes the tokens to determine the grammatical relationships between the tokens (block 1215). The example interpreter 320 translates the identified grammatical relationships into expressions, data and/or configuration information 225 that are specific to particular make(s) and/or model(s) of process control system components (block 1220). Control then exits from the example process of FIG. 12.



FIG. 13 is a schematic diagram of an example processor platform P100 that may be used and/or programmed to implement the example process control system configuration system 150 and/or the example compiler 220 of FIGS. 1, 2 and 3. For example, the processor platform P100 can be implemented by one or more general-purpose processors, processor cores, microcontrollers, etc.


The processor platform P100 of the example of FIG. 13 includes at least one general-purpose programmable processor P105. The processor P105 executes coded instructions P110 and/or P112 present in main memory of the processor P105 (e.g., within a RAM P115 and/or a ROM P120). The processor P105 may be any type of processing unit, such as a processor core, a processor and/or a microcontroller. The processor P105 may execute, among other things, the example processes of FIGS. 11 and/or 12 to implement the example methods and apparatus described herein.


The processor P105 is in communication with the main memory (including a ROM P120 and/or the RAM P115) via a bus P125. The RAM P115 may be implemented by dynamic random access memory (DRAM), synchronous dynamic random access memory (SDRAM), and/or any other type of RAM device(s), and ROM may be implemented by flash memory, EPROM, EEPROM, a CD, a DVD and/or any other desired type of memory device(s). Access to the memory P115 and the memory P120 may be controlled by a memory controller (not shown). The example memory P115 may be used to implement the example EDL script 205, the example EDL library 215, the example system and/or vendor-specific script(s) 225, the example device database 230, the example configuration database 225 and/or the example operation database 265.


The processor platform P100 also includes an interface circuit P130. The interface circuit P130 may be implemented by any type of interface standard, such as an external memory interface, serial port, general-purpose input/output, etc. One or more input devices P135 and one or more output devices P140 are connected to the interface circuit P130.


Although certain example methods, apparatus and articles of manufacture have been described herein, the scope of coverage of this patent is not limited thereto. Such example are intended to be non-limiting illustrative examples. On the contrary, this patent covers all methods, apparatus and articles of manufacture fairly falling within the scope of the appended claims either literally or under the doctrine of equivalents.

Claims
  • 1. A method comprising: loading a first script representative of a process plant, the first script comprising an interpretive system-level script structured in accordance with an electronic description language; andcompiling the first script to form a second script, the second script structured in accordance with a vendor-specific configuration language associated with a particular process control system for the process plant.
  • 2. A method as defined in claim 1, wherein the first script is compile-able to form a third script structured in accordance with a second vendor-specific configuration language associated with a second process control system for at least one of the process plant or a second process plant.
  • 3. A method as defined in claim 1, wherein compiling the first script to form the second script comprises: identifying one or more lexemes contained in the first script;identifying tokens contained in the first script based on the one or more lexemes;identifying one or more grammatical relationships between the tokens; andforming the second script based on the tokens and the grammatical relationships.
  • 4. A method as defined in claim 1, wherein the first script is constructed in accordance with an extensible markup language.
  • 5. A method as defined in claim 1, wherein the first script represents a relationship between a first device of the process control system and a second device of the process control system.
  • 6. A method as defined in claim 5, wherein the first device comprises a field device and the second device comprises a control system component.
  • 7. A method as defined in claim 1, further comprising importing the second script into a process control system configuration database associated with the process control system.
  • 8. A method as defined in claim 1, further comprising: generating a process control system operation database based on the second script; andconfiguring the process control system based on the operation database.
  • 9. An apparatus comprising: an editor useable to create a first script representative of a process plant, the first script comprising an interpretable system-level script structured in accordance with an electronic description language; anda compiler to form a second script from the first script, the second script structured in accordance with a vendor-specific configuration language associated with a particular process control system for the process plant.
  • 10. An apparatus as defined in claim 9, wherein the first script is to be compiled to form a third script, the third script structured in accordance with a second configuration language associated with a second process control system for at least one of the process plant or a second process plant.
  • 11. An apparatus as defined in claim 9, wherein the compiler comprises: a scanner to identify one or more lexemes contained in the first script;a tokenizer to identify tokens contained in the first script based on the one or more lexemes;a parser to identify one or more grammatical relationships between the tokens; andan interpreter to form the second script based on the tokens and the grammatical relationships.
  • 12. An apparatus as defined in claim 9, wherein the first script is constructed in accordance with an extensible markup language.
  • 13. An apparatus as defined in claim 9, wherein the first script represents a relationship between a first device of the process control system and a second device of the process control system.
  • 14. An apparatus as defined in claim 9, further comprising: a database populator to populate a process control system configuration database based on the second script; anda database server to configure the process control system based on the process control system configuration database.
  • 15. An article of manufacture storing machine readable instructions that, when executed, cause a machine to: load a first script representative of a process plant, the first script comprising an interpretive system-level script structured in accordance with an electronic description language; andcompile the first script to form a second script, the second script structured in accordance with a vendor-specific configuration language associated with a particular process control system for the process plant.
  • 16. An article of manufacture as defined in claim 15, wherein the machine readable instructions, when executed, cause the machine to compile the first script to form a third script structured in accordance with a second vendor-specific configuration language associated with a second process control system for at least one of the process plant or a second process plant.
  • 17. An article of manufacture as defined in claim 15, wherein the machine readable instructions, when executed, cause the machine to compile the first script to form the second script by: identifying one or more lexemes contained in the first script;identifying tokens contained in the first script based on the one or more lexemes;identifying one or more grammatical relationships between the tokens; andforming the second script based on the tokens and the grammatical relationships.
  • 18. An article of manufacture as defined in claim 15, wherein the first script represents a relationship between a field device of the process control system and a control system component of the process control system.
  • 19. An article of manufacture as defined in claim 15, wherein the machine readable instructions, when executed, cause the machine to import the second script into a process control system configuration database associated with the process control system.
  • 20. An article of manufacture as defined in claim 15, wherein the machine readable instructions, when executed, cause the machine to: generate a process control system operation database based on the second script; andconfigure the process control system based on the operation database.
  • 21-27. (canceled)