Field device with capability of calculating digital filter coefficients

Information

  • Patent Grant
  • 8301676
  • Patent Number
    8,301,676
  • Date Filed
    Thursday, August 23, 2007
    17 years ago
  • Date Issued
    Tuesday, October 30, 2012
    12 years ago
Abstract
A digital filter design algorithm is implemented directly within a process control field device or other process related equipment. Filter design parameters are exposed so that filter design parameter values may be provided to the digital filter design algorithm so that the digital filter design algorithm may calculate digital filter coefficients for a digital filter having desired frequency response characteristics. The digital filter design parameter values may be provided by a user, or may be provided as process variable data output from a process control field device or other process related equipment. Once the coefficients of the digital filter having the desired frequency response characteristics have been calculated, the digital filter may be applied to process variable data received by the process control field device or other process related equipment.
Description
TECHNICAL FIELD

This disclosure relates generally to implementing a digital filter in a process control field device or other process related equipment. In particular the disclosure relates to providing a digital filter design algorithm within an abnormal situation prevention block associated with a smart field device or other intelligent process related equipment.


DESCRIPTION OF THE RELATED ART

Process control systems, like those used in chemical, petroleum or other process plants, typically include one or more centralized or decentralized process controllers. Process controllers may be communicatively coupled to at least one host or operator workstation and to one or more process control and instrumentation devices. Process control and instrumentation devices may comprise, for example, field devices. The one or more centralized or decentralized controllers may be communicatively coupled to the at least one host or workstation and the one or more process control and instrumentation devices via one or more analog, digital or combined analog/digital buses. Field devices, which may be, for example, valves, valve positioners, switches, transmitters, and sensors (e.g., temperature, pressure, and flow rate sensors), are typically located within the process plant environment. The field devices perform functions within the process such as opening or closing valves, measuring process parameters, increasing or decreasing fluid flow, etc. Smart field devices such as field devices conforming to the well-known FOUNDATION™ fieldbus (hereafter “fieldbus”) protocol or the HART® protocol may also perform control calculations, alarming functions, and other control functions commonly implemented within the process controller.


The process controllers, which are typically located within the process plant environment, receive signals indicative of process measurements or process variables made by or associated with the field devices and/or other information pertaining to the field devices, and execute controller applications. The controller applications implement, for example, different control modules that make process control decisions, generate control signals based on the received information, and coordinate with the control modules or blocks in the field devices such as HART® and fieldbus field devices. The control modules in the process controllers send the control signals over the communication lines or signal paths to the field devices, to thereby control the operation of the process.


Information from the field devices and the process controllers is typically made available to one or more other hardware devices such as, for example, operator workstations, maintenance workstations, personal computers, handheld devices, data historians, report generators, centralized databases, etc., to enable an operator or a maintenance person to perform desired functions with respect to the process such as, for example, changing settings of the process control routine, modifying the operation of the control modules within the process controllers or the smart field devices, viewing the current state of the process or of particular devices within the process plant, viewing alarms generated by field devices and process controllers, simulating the operation of the process for the purpose of training personnel or testing the process control software, diagnosing problems or hardware failures within the process plant, etc.


While a typical process plant has many process control and instrumentation devices such as valves, transmitters, sensors, etc., connected to one or more process controllers, there are many other supporting devices that are also necessary for or related to process operation. These additional devices include, for example, power supply equipment, power generation and distribution equipment, rotating equipment such as turbines, motors, etc., which are located at numerous places in a typical plant. While this additional equipment does not necessarily create or use process variables and, in many instances, is not controlled or even coupled to a process controller for the purpose of affecting the process operation, this equipment is nevertheless important to, and ultimately necessary for proper operation of the process.


As is known, problems frequently arise within a process plant environment, especially a process plant having a large number of field devices and supporting equipment. These problems may take the form of broken or malfunctioning devices, logic elements, such as software routines being in improper modes, improperly tuned process control loops, one or more failures in communications between devices within the process plant, etc. These and other problems, while numerous in nature, generally result in the process operating in an abnormal state (i.e., the process plant being in an abnormal condition) which is usually associated with suboptimal performance of the process plant.


Many diagnostic tools and applications have been developed to detect and determine the cause of problems within a process plant and to assist an operator or a maintenance person to diagnose and correct the problems once the problems have occurred and been detected. For example, operator workstations, which are typically connected to the process controllers through communication connections such as a direct or wireless bus, Ethernet, modem, phone line, and the like, have processors and memories that are adapted to run software or firmware, such as the DeltaV™ and Ovation control systems, sold by Emerson Process Management, which include numerous control module and control loop diagnostic tools. Likewise, maintenance workstations, which may be connected to the process control devices, such as field devices, via the same communication connections as the controller applications, or via different communication connections, such as object linking and embedding (OLE) for process control (OPC) connections, handheld connections, etc., typically include one or more applications designed to view maintenance alarms and alerts generated by field devices within the process plant, to test devices within the process plant and to perform maintenance activities on the field devices and other devices within the process plant. Similar diagnostic applications have been developed to diagnose problems within the supporting equipment within the process plant.


Thus, for example, the Asset Management Solutions (AMS™) Suite: Intelligent Device Manager application (at least partially disclosed in U.S. Pat. No. 5,960,214 entitled “Integrated Communication Network for use in a Field Device Management System”) sold by Emerson Process Management, enables communication with and stores data pertaining to field devices to ascertain and track the operating state of the field devices. In some instances, the AMS™ application may be used to communicate with a field device to change parameters within the field device, to cause the field device to run applications on itself such as, for example, self-calibration routines or self-diagnostic routines, to obtain information about the status or health of the field device, etc. This information may include, for example, status information (e.g., whether an alarm or other similar event has occurred), device configuration information (e.g., the manner in which the field device is currently or may be configured and the type of measuring units used by the field device), device parameters (e.g., the field device range values, and other parameters), etc. Of course, a maintenance person may use this information to monitor, maintain, and/or diagnose problems with field devices.


Similarly, many process plants include equipment monitoring and diagnostic applications such as, for example, RBMware provided by CSI Systems, or any other known applications used to monitor, diagnose, and optimize the operating state of various rotating equipment. Maintenance personnel usually use these applications to maintain and oversee the performance of rotating equipment in the plant, to determine problems with the rotating equipment, and to determine when and if the rotating equipment must be repaired or replaced. Similarly, many process plants include power control and diagnostic applications such as those provided by, for example, the Liebert and ASCO companies, to control and maintain the power generation and distribution equipment. It is also known to run control optimization applications such as, for example, real-time optimizers (RTO+), within a process plant to optimize the control activities of the process plant. Such optimization applications typically use complex algorithms and/or models of the process plant to predict how inputs may be changed to optimize operation of the process plant with respect to some desired optimization variable such as, for example, profit.


These and other diagnostic and optimization applications are typically implemented on a system-wide basis in one or more of the operator or maintenance workstations, and may provide preconfigured displays to the operator or maintenance personnel regarding the operating state of the process plant, or the devices and equipment within the process plant. Typical displays include alarming displays that receive alarms generated by the process controllers or other devices within the process plant, control displays indicating the operating state of the process controllers and other devices within the process plant, maintenance displays indicating the operating state of the devices within the process plant, etc. Likewise, these and other diagnostic applications may enable an operator or a maintenance person to retune a control loop or to reset other control parameters of field devices, to run a test on one or more field devices to determine the current status of those field devices, to calibrate field devices or other equipment, or to perform other problem detection and correction activities on field devices and other equipment within the process plant.


A process control system may further include an abnormal situation prevention system. An abnormal situation prevention system may reside, at least in part, on a computer or workstation. The computer or workstation implementing at least a portion of an abnormal situation prevention system may communicate with controllers and other equipment within the process plant such as field devices, rotating equipment, power generation equipment, other workstations or support computers, and the like. The controllers and other equipment may include additional components of the abnormal situation prevention system, such as abnormal operation detection systems and abnormal situation prevention modules or tools, including abnormal situation prevention blocks.


Abnormal situation prevention blocks may be located in various controllers, field devices or other equipment. The abnormal situation prevention blocks may include specific routines or techniques for detecting, predicting, and preventing abnormal situations from occurring within the particular type of equipment in which the abnormal situation prevention blocks are located abnormal situation prevention blocks may further include statistical process monitoring (SPM) blocks. SPM blocks collect and process variable data and perform statistical processing on the collected data to determine one or more statistical measures associated with the collected data, such as the mean or the standard deviation of a process variable, and so forth. The abnormal situation prevention blocks may perform additional processing on collected process variable data not typically provided by SPM blocks. For example, an abnormal situation prevention block may provide a digital filter for filtering raw process variable data received from a field device.


When a process control routine requires filtered process variable data, a digital filter may be implemented by an abnormal situation prevention block located directly in or near the particular field device or other process related equipment that measures or otherwise receives the process control variable data. For example, published U.S. Patent Application No. 20070010900 Diagnostics In Industrial Process Control System, filed Apr. 4, 2006, the teaching of which is incorporated herein by reference, describes abnormal situation prevention blocks incorporating various filters. When a digital filter is implemented an operator or maintenance person may choose a generic high pass filter, or low pass filter, or a custom digital filter. Generic high pass or low pass filters may be employed in situations where the user qualitatively wants to filter out the high or low frequency components of a signal, but does not know precisely the frequency of interest. A custom filter allows the user to design a specific filter for a particular application. In one implementation of an abnormal situation prevention block, the custom filter may comprise a 16th order finite impulse response (FIR) filter. In many implementations, the order of the digital filter may be limited by the computational resources in the field device. When a custom filter is selected, the user must design the filter, calculating the coefficients necessary to produce the desired frequency response using an external filter design tool such as Matlab, or the like. Once the coefficients have been calculated the user must manually enter each of the different coefficients into the field device using an appropriate interface tool and communication protocol. In the case where the custom filter is a 16th order FIR filter, the user must use an external filter design tool to calculate 17 coefficients, and enter these 17 coefficients into the field device using an appropriate interface tool and communication protocol.


The ability to create a custom filter offers users great flexibility for filtering raw process variable data. A custom filter allows an operator or maintenance person to monitor specific frequency bands within the received data. Implementing a custom filter, however, is a cumbersome process. Designing the filter, calculating the filter coefficients, and manually entering the coefficients into the field device takes a significant amount of time and effort. Implementing a new custom filter for filtering raw process data is not a task that one would want to repeat over and over again on a regular basis. Manually entering all of the coefficients associated with a 16th order digital filter is especially burdensome and is prone to errors. Therefore, under the current regime, implementing a custom filter is not a practical option for situations in which the desired characteristics of a particular digital filter may change over time. An operator or maintenance person will not want to design a new filter, calculate new coefficients and manually enter the new filter coefficients each time the process conditions require a filter having a different frequency response. Furthermore, the current procedure for implementing a custom filter in an abnormal situation prevention block associated with a field device or other process related equipment does not lend itself to dynamic changes. Under certain circumstances, the filter characteristics may need to be changed “on-the-fly” while the process is in progress. The current procedure does not allow digital filter characteristics to be changed or updated as process conditions demand.


SUMMARY OF THE DISCLOSURE

The present disclosure relates to implementing a digital filter in a process control field device or other process related equipment. A digital filter design algorithm, such as the Parks-McClellan filter design algorithm, is implemented directly within a process control field device or other process related equipment. Filter design parameters are exposed via an interface associated with a process configuration tool. A user may enter filter design parameter values corresponding to the frequency response characteristics of a desired filter, and the filter design algorithm calculates digital filter coefficients based on the entered filter design parameters. The process control field device or other process related equipment may then apply the digital filter to process variable data measured by the process control field device or other process related equipment. Alternatively, the digital filter design algorithm may be implemented as an abnormal situation prevention function block such that one or more of the digital filter design parameters may be calculated directly within the process control logic. In this case, process variable data may be input to the abnormal situation prevention function block such that one or more filter design parameters may be based on one or more process operating conditions.


According to an embodiment, a system for implementing a digital filter for filtering process variable data includes an intelligent device, such as a smart field device, for implementing a digital filter design algorithm. An interface exposes digital filter design parameters so that digital filter design parameter values may be provided to the digital filtered design algorithm. The intelligent device executes the digital filter design algorithm using the digital filter design parameter values to create a digital filter having desired frequency response characteristics. The intelligent device may then apply the digital filter to received process variable data.


Another embodiment calls for an intelligent process control device. The intelligent process control device includes a processor and a memory. The memory stores a digital filter design algorithm to be executed by the processor. A first input is adapted to receive digital filter design parameter values. The digital filter design parameter values specify various frequency response characteristics of the desired digital filter. A second input is adapted to receive process variable data. The processor executes the digital filter design algorithm using the received digital filter design parameter values to create a digital filter having the desired frequency response characteristics. The processor then applies the digital filter to the received process variable data.


Yet another embodiment provides a method of filtering process variable data. The method calls for implementing a digital filter design algorithm in a process related control device. One or more filter design parameters are exposed to an interface so that filter design parameter values may be provided to the digital filter design algorithm. Once the digital filter design parameters have been provided to the digital filter design algorithm, the method calls for calculating digital filter coefficients using the digital filter design algorithm and the digital filter design parameter values. When the digital filter coefficients have been calculated, the digital filter may be applied to raw process variable data to remove frequency components outside a particular frequency band of interest.


Further aspects and advantages will be apparent to those of ordinary skill in the art from a review of the following detailed description, taken in conjunction with the drawings. While the compositions and methods are susceptible of embodiments in various forms, the description hereafter includes specific embodiments with the understanding that the disclosure is illustrative, and is not intended to limit the invention to the specific embodiments described herein.





BRIEF DESCRIPTION OF THE DRAWINGS


FIG. 1 is an exemplary block diagram of a process plant having a distributed control and maintenance network including one or more operator and maintenance workstations, controllers, field devices and supporting equipment, in which an abnormal situation prevention system may be implemented;



FIG. 2 is an exemplary block diagram of a portion of the process plant of FIG. 1 illustrating communication interconnections between various components of an abnormal situation prevention system located within different elements of the process plant;



FIG. 3 is a frequency plot showing the frequency response of a low pass digital filter created using the Parks-McClellan Algorithm;



FIG. 4 is a frequency plot showing the frequency response of a high pass digital filter created using the Parks McClellan Algorithm;



FIG. 5 is a frequency plot showing the frequency response of a bandpass filter created using the Parks-McClellan Algorithm;



FIG. 6 is a screen shot of a configuration tool interface page exposing digital filter design parameters;



FIG. 7 is a screen shot of a configuration tool interface page for implementing a digital filter design algorithm as a function block within an abnormal situation prevention system.





DETAILED DESCRIPTION

Referring now to FIG. 1, an exemplary process plant 10 in which an abnormal situation prevention system may be implemented includes a number of control and maintenance systems interconnected together with supporting equipment via one or more communication networks. In particular, the process plant 10 of FIG. 1 includes one or more process control systems 12 and 14. The process control system 12 may be a traditional process control system such as a PROVOX or RS3 system or any other control system which includes an operator interface 12A coupled to a controller 12B and to input/output (I/O) cards 12C which, in turn, are coupled to various field devices such as analog and Highway Addressable Remote Transmitter (HART®) field devices 15. The process control system 14, which may be a distributed process control system, includes one or more operator interfaces 14A coupled to one or more distributed controllers 14B via a bus, such as an Ethernet bus. The controllers 14B may be, for example, DeltaV™ controllers sold by Emerson Process Management of Austin, Tex. or any other desired type of controllers. The controllers 14B are connected via I/O devices to one or more field devices 16, such as for example, HART® or fieldbus field devices or any other smart or non-smart field devices including, for example, those that use any of the PROFIBUS®, WORLDFIP®, Device-Net®, AS-Interface and CAN protocols. As is known, the field devices 16 may provide analog or digital information to the controllers 14B related to process variables as well as to other device information. The operator interfaces 14A may store and execute tools 17, 19 available to the process control operator for controlling the operation of the process including, for example, control optimizers, diagnostic experts, neural networks, tuners, etc.


Still further, maintenance systems, such as computers executing the AMS™ application and/or the monitoring, diagnostics and communication applications described below may be connected to the process control systems 12 and 14 or to the individual devices therein to perform maintenance, monitoring, and diagnostics activities. For example, a maintenance computer 18 may be connected to the controller 12B and/or to the devices 15 via any desired communication lines or networks (including wireless or handheld device networks) to communicate with and, in some instances, reconfigure or perform other maintenance activities on the devices 15. Similarly, maintenance applications such as the AMS™ application may be installed in and executed by one or more of the user interfaces 14A associated with the distributed process control system 14 to perform maintenance and monitoring functions, including data collection related to the operating status of the devices 16.


The process plant 10 also includes various rotating (and other) equipment 20, such as turbines, motors, etc. which are connected to a maintenance computer 22 via some permanent or temporary communication link (such as a bus, a wireless communication system or hand held devices which are connected to the equipment 20 to take readings and are then removed). The maintenance computer 22 may store and execute any number of monitoring and diagnostic applications 23, including commercially available applications, such as those provided by CSI (an Emerson Process Management Company), as well the applications, modules, and tools described below, to diagnose, monitor and optimize the operating state of the rotating equipment 20 and other equipment in the plant. Maintenance personnel usually use the applications 23 to maintain and oversee the performance of rotating equipment 20 in the plant 10, to determine problems with the rotating equipment 20 and to determine when and if the rotating equipment 20 must be repaired or replaced. In some cases, outside consultants or service organizations may temporarily acquire or measure data pertaining to the equipment 20 and use this data to perform analyses for the equipment 20 to detect problems, poor performance or other issues effecting the equipment 20. In these cases, the computers running the analyses may not be connected to the rest of the system 10 via any communication line or may be connected only temporarily.


Similarly, a power generation and distribution system 24 having power generating and distribution equipment 25 associated with the plant 10 is connected via, for example, a bus, to another computer 26 which runs and oversees the operation of the power generating and distribution equipment 25 within the plant 10. The computer 26 may execute known power control and diagnostics applications 27 such as those provided by, for example, Liebert and ASCO or other companies to control and maintain the power generation and distribution equipment 25. Again, in many cases, outside consultants or service organizations may use service applications that temporarily acquire or measure data pertaining to the equipment 25 and use this data to perform analyses for the equipment 25 to detect problems, poor performance or other issues effecting the equipment 25. In these cases, the computers (such as the computer 26) running the analyses may not be connected to the rest of the system 10 via any communication line or may be connected only temporarily.


As illustrated in FIG. 1, a computer system 30 implements at least a portion of an abnormal situation prevention system 35, and in particular, the computer system 30 stores and implements a configuration application 38 and, optionally, an abnormal operation detection system 42. Additionally, the computer system 30 may implement an alert/alarm application 43.


Generally speaking, the abnormal situation prevention system 35 may communicate with (or include) abnormal operation detection systems, modules or tools (not shown in FIG. 1) optionally located in the field devices 15, 16, the controllers 12B, 14B, the rotating equipment 20, the support computer 22, the power generation equipment 25 or support computer 26, or any other desired devices and equipment within the process plant 10. The abnormal situation prevention system 35 may also interact with the abnormal operation detection system 42 in the computer system 30, to configure each of these abnormal operation detection systems and to receive information regarding the operation of the devices or subsystems that they are monitoring. The abnormal situation prevention system 35 may be communicatively connected via a hardwired bus 45 to each or at least some of the computers or devices within the plant 10, or, alternatively may be connected via any other desired communication connection including, for example, wireless connections, dedicated connections which use OPC (or OLE for process control), intermittent connections, such as ones which rely on handheld devices to collect data, etc. Likewise, the abnormal situation prevention system 35 may obtain data pertaining to the field devices and equipment within the process plant 10 via a LAN or a public connection, such as the Internet, a telephone connection, etc. (illustrated in FIG. 1 as an Internet connection 46) with such data being collected by, for example, a third party service provider. Further, the abnormal situation prevention system 35 may be communicatively coupled to computers/devices in the plant 10 via a variety of techniques and/or protocols including, for example, Ethernet, Modbus, HTML, XML, proprietary techniques/protocols, etc. Thus, although particular examples using OPC to communicatively couple the abnormal situation prevention system 35 to computers/devices in the plant 10 are described herein, one of ordinary skill in the art will recognize that a variety of other methods of coupling the abnormal situation prevention system 35 to computers/devices in the plant 10 can be used as well.


By way of background, OPC is a standard that establishes a mechanism for accessing process data from the plant or process control system. Typically, an OPC server is implemented in a process control system to expose or provide process information from, for example, field devices. An OPC client creates a connection to an OPC server and writes or reads process information to or from a field device. OPC servers use OLE technology (i.e., Component Object Model or COM) to communicate with such clients so that the software applications implemented by the clients can access data from the field devices or other process plant equipment.



FIG. 2 illustrates a portion 50 of the example process plant 10 of FIG. 1 for the purpose of describing one manner in which the abnormal situation prevention system 35 and/or the alert/alarm application 43 may communicate with various devices in the portion 50 of the example process plant 10. While FIG. 2 illustrates communications between the abnormal situation prevention system 35 and one or more abnormal operation detection systems within HART® and fieldbus field devices, it will be understood that similar communications can occur between the abnormal situation prevention system 35 and other devices and equipment within the process plant 10, including any of the devices and equipment illustrated in FIG. 1.


The portion 50 of the process plant 10 illustrated in FIG. 2 includes a distributed process control system 54 having one or more process controllers 60 connected to one or more field devices 64 and 66 via input/output (I/O) cards or devices 68 and 70, which may be any desired types of I/O devices conforming to any desired communication or controller protocol. The field devices 64 are illustrated as HART® field devices and the field devices 66 are illustrated as fieldbus field devices, although these field devices could use any other desired communication protocols. Additionally, each of the field devices 64 and 66 may be any type of device such as, for example, a sensor, a valve, a transmitter, a positioner, etc., and may conform to any desired open, proprietary or other communication or programming protocol, it being understood that the I/O devices 68 and 70 must be compatible with the desired protocol used by the field devices 64 and 66.


In any event, one or more user interfaces or computers 72 and 74 (which may be any types of personal computers, workstations, etc.) accessible by plant personnel such as configuration engineers, process control operators, maintenance personnel, plant managers, supervisors, etc. are coupled to the process controllers 60 via a communication line or bus 76 which may be implemented using any desired hardwired or wireless communication structure, and using any desired or suitable communication protocol such as, for example, an Ethernet protocol. In addition, a database 78 may be connected to the communication bus 76 to operate as a data historian that collects and stores configuration information as well as on-line process variable data, parameter data, status data, and other data associated with the process controllers 60 and field devices 64 and 66 within the process plant 10. Thus, the database 78 may operate as a configuration database to store the current configuration, including process configuration modules, as well as control configuration information for the process control system 54 as downloaded to and stored within the process controllers 60 and the field devices 64 and 66. Likewise, the database 78 may store historical abnormal situation prevention data, including statistical data collected by the field devices 64 and 66 within the process plant 10, statistical data determined from process variables collected by the field devices 64 and 66, and other types of data that will be described below.


While the process controllers 60, I/O devices 68 and 70, and field devices 64 and 66 are typically located down within and distributed throughout the sometimes harsh plant environment, the workstations 72 and 74, and the database 78 are usually located in control rooms, maintenance rooms or other less harsh environments easily accessible by operators, maintenance personnel, etc.


Generally speaking, the process controllers 60 store and execute one or more controller applications that implement control strategies using a number of different, independently executed, control modules or blocks. The control modules may each be made up of what are commonly referred to as function blocks, wherein each function block is a part or a subroutine of an overall control routine and operates in conjunction with other function blocks (via communications called links) to implement process control loops within the process plant 10. As is well known, function blocks, which may be objects in an object-oriented programming protocol, typically perform one of an input function, such as that associated with a transmitter, a sensor or other process parameter measurement device, a control function, such as that associated with a control routine that performs PID, fuzzy logic, etc. control, or an output function, which controls the operation of some device, such as a valve, to perform some physical function within the process plant 10. Of course, hybrid and other types of complex function blocks exist, such as model predictive controllers (MPCs), optimizers, etc. It is to be understood that while the fieldbus protocol and the DeltaV™ system protocol use control modules and function blocks designed and implemented in an object-oriented programming protocol, the control modules may be designed using any desired control programming scheme including, for example, sequential function blocks, ladder logic, etc., and are not limited to being designed using function blocks or any other particular programming technique.


As illustrated in FIG. 2, the maintenance workstation 74 includes a processor 74A, a memory 74B and a display device 74C. The memory 74B stores the abnormal situation prevention application 35 and the alert/alarm application 43 discussed with respect to FIG. 1 in a manner that these applications can be implemented on the processor 74A to provide information to a user via the display 74C (or any other display device, such as a printer).


Each of one or more of the field devices 64 and 66 may include a memory (not shown) for storing routines such as routines for implementing statistical data collection pertaining to one or more process variables sensed by sensing device and/or routines for abnormal operation detection, which will be described below. Each of one or more of the field devices 64 and 66 may also include a processor (not shown) that executes routines such as routines for implementing statistical data collection and/or routines for abnormal operation detection. Statistical data collection and/or abnormal operation detection need not be implemented by software. Rather, one of ordinary skill in the art will recognize that such systems may be implemented by any combination of software, firmware, and/or hardware within one or more field devices and/or other devices.


As shown in FIG. 2, some (and potentially all) of the field devices 64 and 66 include abnormal operation detection (i.e., abnormal situation prevention, or abnormal situation prevention) blocks 80 and 82, which will be described in more detail below. While the blocks 80 and 82 of FIG. 2 are illustrated as being located in one of the devices 64 and in one of the devices 66, these or similar blocks could be located in any number of the field devices 64 and 66, could be located in other devices, such as the controller 60, the I/O devices 68, 70 or any of the devices illustrated in FIG. 1. Additionally, the blocks 80 and 82 could be in any subset of the devices 64 and 66.


Generally speaking, the blocks 80 and 82 or sub-elements of these blocks, collect data, such as process variable data, from the device in which they are located and/or from other devices. Additionally, the blocks 80 and 82 or sub-elements of these blocks may process the variable data and perform an analysis on the data for any number of reasons. For example, the block 80, which is illustrated as being associated with a valve, may have a stuck valve detection routine which analyzes the valve process variable data to determine if the valve is in a stuck condition. In addition, the block 80 may include a set of one or more statistical process monitoring (SPM) blocks or units such as blocks SPM1-SPM4 which may collect process variable or other data within the field device and perform one or more statistical calculations on the collected data to determine, for example, a mean, a median, a standard deviation, a root-mean-square (RMS), a rate of change, a range, a minimum, a maximum, etc. of the collected data and/or to detect events such as drift, bias, noise, spikes, etc., in the collected data. Neither the specific statistical data generated, nor the method in which it is generated, is critical. Thus, different types of statistical data can be generated in addition to, or instead of, the specific types described above. Additionally, a variety of techniques, including known techniques, can be used to generate such data. The term statistical process monitoring (SPM) block is used herein to describe functionality that performs statistical process monitoring on at least one process variable or other process parameter, and may be performed by any desired software, firmware or hardware within the device or even outside of a device for which data is collected. It will be understood that, because the SPMs are generally located in the devices where the device data is collected, the SPMs can acquire quantitatively more and qualitatively more accurate process variable data. As a result, the SPM blocks are generally capable of determining better statistical calculations with respect to the collected process variable data than a block located outside of the device in which the process variable data is collected.


Although the blocks 80 and 82 are shown to include SPM blocks in FIG. 2, the SPM blocks may instead be stand-alone blocks separate from the blocks 80 and 82, and may be located in the same device as the corresponding block 80 or 82 or may be in a different device. The SPM blocks discussed herein may comprise known fieldbus SPM blocks, or SPM blocks that have different or additional capabilities as compared with known fieldbus SPM blocks. The term statistical process monitoring (SPM) block is used herein to refer to any type of block or element that collects data, such as process variable data, and performs some statistical processing on this data to determine a statistical measure, such as a mean, a standard deviation, etc. As a result, this term is intended to cover software, firmware, hardware and/or other elements that perform this function, whether these elements are in the form of function blocks, or other types of blocks, programs, routines or elements and whether or not these elements conform to the fieldbus protocol, or some other protocol, such as Profibus, HART®, CAN, etc. protocol. If desired, the underlying operation of blocks 80, 82 may be performed or implemented at least partially as described in U.S. Pat. No. 6,017,143, which is hereby incorporated by reference herein.


It is to be understood that although the blocks 80 and 82 are shown to include SPM blocks in FIG. 2, SPM blocks are not required of the blocks 80 and 82. For example, abnormal operation detection routines of the blocks 80 and 82 could operate using process variable data not processed by an SPM block. As another example, the blocks 80 and 82 could each receive and operate on data provided by one or more SPM blocks located in other devices. As yet another example, the process variable data could be processed in a manner that is not provided by many typical SPM blocks. As just one example, the process variable data could be filtered by a finite impulse response (FIR) or infinite impulse response (IIR) filter such as a bandpass filter or some other type of filter. As another example, the process variable data could be trimmed so that it remained in a particular range. Of course, known SPM blocks could be modified to provide such different or additional processing capabilities.


The block 82 of FIG. 2, which is illustrated as being associated with a transmitter, may have a plugged line detection unit that analyzes the process variable data collected by the transmitter to determine if a line within the plant is plugged. In addition, the block 82 may include one or more SPM blocks or units such as blocks SPM1-SPM4 which may collect process variable or other data within the transmitter and perform one or more statistical calculations on the collected data to determine, for example, a mean, a median, a standard deviation, etc. of the collected data. While the blocks 80 and 82 are illustrated as including four SPM blocks each, the blocks 80 and 82 could have any other number of SPM blocks therein for collecting and determining statistical data.


Further details regarding the implementation and configuration of abnormal situation prevention systems and components thereof can be found in U.S. Pat. Publ. No. 2005/0197803, now U.S. Pat. No. 7,079,984 (“abnormal situation prevention in a process plant”), U.S. Pat. Publ. No. 2005/0197806 (“Configuration system and method for abnormal situation prevention in a process plant”), and U.S. Pat. Publ. No. 2005/0197805 (“Data presentation system for abnormal situation prevention in the process plant”), each of which is hereby incorporated by reference for all purposes.


In the abnormal situation prevention systems and techniques described above and in the referenced documents, the SPM (or abnormal situation prevention) blocks 80, 82 may be associated with, or considered components of, one or more abnormal situation prevention modules. While abnormal situation prevention blocks may reside in a field device, where the faster-sampled data is available, abnormal situation prevention modules may reside in a host system or controller. The abnormal situation prevention modules may take data from one or more abnormal situation prevention blocks, and use the data to make a decision about the larger system. More generally, an abnormal situation prevention module may be developed and configured to receive data from one or more function blocks (e.g., Abnormal situation prevention blocks) to support diagnostics for each type of field device, instrumentation or other equipment (e.g., valve, pump, etc.). Nonetheless, the function blocks associated with an abnormal situation prevention module may reside and be implemented by devices other than the specific equipment for which it was developed. In such cases, the abnormal situation prevention module has a distributed nature. Other abnormal situation prevention modules may be implemented entirely within one device, such as the process controller 60, despite being directed to diagnostics for a specific field device. In any event, a diagnostics routine or technique may be developed for each equipment type for detecting, predicting and preventing abnormal situations or operation of the equipment (or process). For ease in description only, the term “abnormal situation prevention module” will be used herein to refer to such routines or techniques. An abnormal situation prevention module is therefore responsive to a set of measurements needed to perform the diagnostics, and further includes (i) a set of abnormal conditions to be detected by the module, and (ii) a set of rules, which link a change in the measurements to a corresponding abnormal condition. Furthermore, references to abnormal situation prevention modules in the description of the disclosed techniques to follow are set forth with the understanding that the techniques may be utilized in conjunction with abnormal situation prevention blocks as well.


In some cases, the configuration application 38 or other component of the abnormal situation prevention system 35 may support the development or generation of a template for each abnormal situation prevention module. For example, the configuration and development platform provided by the DeltaV™ control system may be used to create specific instances, or instantiations, of abnormal situation prevention modules from corresponding composite template blocks.


Although shown and described in connection with FIG. 2 as abnormal situation prevention functionality, the modules and blocks described above may be more generally directed to implementing multivariate statistical techniques configured for process monitoring and diagnostics and fault detection. In some cases, the techniques described below may include or be integrated with abnormal situation prevention modules or blocks. In any case, references below to systems and techniques (and any modules, function blocks, applications, software or other components or aspects thereof) may utilize, include, be integrated with, or otherwise be associated with the workstation tools 17, 19, operator interfaces 12A, 14A, applications 23, abnormal situation prevention system 25 and interfaces 72, 74 described above.


As mentioned above, the abnormal operation detection routines executed by the abnormal situation prevention blocks may process variable data in ways not provided by typical SPM blocks. Filtering process variable data is one example of the type of processing that may be performed by an abnormal situation prevention block 80, 82 that is not provided by typical SPM blocks. A digital filter may be implemented within an abnormal situation prevention block for filtering process variable data received from the field device in which the abnormal situation prevention block is located or data received from another remote field device or other remote equipment. The process variable data may be filtered by a finite impulse response (FIR) filter, or an infinite impulse response (by IIR) filter such as a low pass filter, high pass filter, bandpass filter, or some other type of filter implemented by the abnormal situation prevention block.


abnormal situation prevention blocks have been developed implementing a number of filters having different frequency response characteristics. Preconfigured digital filters implemented in abnormal situation prevention blocks, include a low pass and high pass filters, as well as bandpass filters having common cut off frequencies and other typical frequency response characteristics. Furthermore, abnormal situation prevention blocks have been provided for implementing custom digital filters, such as a 16th order FIR digital filter. For example, a 16th order custom digital filter has been implemented in one implementation of an abnormal situation prevention block adapted to be executed by a smart field device conforming to the well-known fieldbus or HART® protocols. However, as has been described, implementing such a filter is a fairly difficult task. An operator must first calculate the filter coefficients of the custom digital filter using a filter design tool. Once the coefficients have been calculated, they must be manually entered into the field device via a user interface or other configuration tool. In the case where the filter is a 16th order FIR filter, the operator must calculate 17 coefficients, and enter them all into the field device. While this procedure may be acceptable for situations where the filter coefficients only need to be calculated and entered once, it is wholly inadequate for situations where the necessary filter characteristics may change over time, or where a different frequency response is required for different process operating conditions.


An improved method for implementing a digital filter having a customized frequency response is to calculate the filter coefficients directly within an abnommal situation prevention block associated with a field device or other process related equipment. There are many algorithms available for calculating the optimal coefficients of the digital filter of a particular order and having desired frequency response characteristics. Equiripple filter design algorithms are often the best suited algorithms for many applications. Equiripple filter design algorithms minimize the “worst case response” of a filter. In other words, equiripple filter design algorithms reduce the maximum ripple of the filter's frequency response in the frequency band of interest. The Remez Exchange algorithm was the first equiripple filter design algorithm developed to reduce the magnitude of the maximum ripple in the frequency bands of interest. Today the Parks-McClellan algorithm is the most commonly used. An embodiment of an abnormal situation prevention block adapted to calculate digital filter coefficients and implement a corresponding digital filter may employ the Parks-McClellan algorithm, the Remez Exchange algorithm, or any other filter design algorithm capable of determining the coefficients of a digital filter having the desired frequency response characteristics.



FIG. 3 is a frequency plot 100 showing the frequency response of a low pass digital filter having coefficients calculated using the Parks-McClellan algorithm. The frequency plot 100 shows an ideal frequency response curve 102, and the actual frequency response curve 104 of a digital filter having coefficients calculated using the Parks-McClellan algorithm. The low pass filter has a cut off frequency 106 of 3 Hz, and a transition region with a width 108 of 2 Hz. The width of the transition region may be referred to as the “transition width.” As can be seen, the actual frequency response curve 104 includes a small amount of ripple 110.



FIG. 4 is a frequency plot 112 showing the frequency response of a high pass digital filter having coefficients calculated using the Parks-McClellan algorithm. The frequency plot 112 also shows an ideal frequency response curve 114 and the actual frequency response curve 116 of a digital filter having coefficients calculated using the Parks-McClellan algorithm. The high pass filter has a cut off frequency 118 of 7 Hz, and a transition width 120 of 1 Hz. Again, the actual frequency response curve 116 includes a small amount of ripple 122. The ripple 122 in the frequency response curve 116 of the high pass filter is greater than the ripple 110 in the frequency response curve 104 of the low pass filter due to the narrower transition width between the pass band and the stop band of the high pass filter.



FIG. 5 is a frequency plot 124 showing the frequency response of a digital bandpass filter having coefficients calculated using the Parks-McClellan algorithm. The frequency plot 124 shows the ideal frequency response curve 126 and the actual frequency response 128 of a digital filter having coefficients calculated using the Parks-McClellan algorithm. The bandpass filter has a low frequency cut off frequency of 3 Hz and a high frequency cut off frequency of 5 Hz. The center frequency of the passband is 4 Hz. The frequency response has a low frequency transition width 134 and a high frequency transition width 136 of 1 Hz. The actual frequency response curve includes ripple 138.


In order to use the Parks-McClellan algorithm to calculate digital filter coefficients, one must specify the order of the filter and the values of various parameters that define the desired frequency response. For example, when designing a digital filter using the Parks-McClellan algorithm one may specify whether the filter is to be a low pass filter, a high pass filter, or a bandpass filter. If the filter is to be a low pass or a high pass filter, one may specify the cutoff frequency and the width of the transition region between the passband and the stop band. If the filter is to be a bandpass filter, one may specify the center frequency of the passband, the width of the passband, and the widths of the transition regions between the passband and the stopband. Alternatively, rather than specifying the center frequency and the width of the passband, one may specify the low frequency cut off frequency and the high-frequency cut off frequency of the desired passband. However, a drawback to specifying the passband in this manner is that if at a later time the passband needs to be shifted to a higher or lower frequency band, both the low frequency cut off and the high-frequency cut off parameters must be changed, whereas if the center frequency and the width of the passband are defined, only the center frequency value needs to be updated in order to shift the passband to a higher or lower frequency range.


In order to implement the Parks-McClellan algorithm within an abnormal situation prevention block associated with a field device or other process related equipment, the filter type (low pass, high pass, bandpass, etc.), the cut off frequency, transition width, or in the case of a bandpass filter, the center frequency and the passband width or the high frequency and low frequency cut off frequencies, and the transition widths must be configurable parameters of the abnormal situation prevention block implemented in the field device or other process related equipment. The configurable parameters of the abnormal situation prevention block must be exposed via an appropriate communication protocol (e.g. Harts or fieldbus) and an appropriate interface device to allow authorized personnel to enter parameter values to configure a digital filter having the desired characteristics. The appropriate interface device may comprise any process related equipment configuration tool, such as a hand-held communicator (e.g. the 375 Field Communicator from Emerson Process Management), a computer workstation, with software for field device configuration, (e.g. AMS™ Device Manager from Emerson Process Management), or a control system (e.g. DeltaV or Ovation, also from Emerson Process Management).


Exposing the configurable filter parameters associated with an abnormal situation prevention block implementing a configurable custom filter in a field device or other process related equipment may include, for example, implementing the configurable parameters in the field device or other process related equipment as parameters conforming to a known digital communication, such as HART® or fieldbus, and creating a device description (DD) file, defining these parameters. The field device's or other process related equipment's device description may then be imported into a configuration tool, which may include an interface application for displaying the configurable filter parameters to a user, and allowing the user to enter values for the various parameters corresponding to the desired filter characteristics.


For example, FIG. 6 shows a device configuration page 140 of the DeltaV distributed control system from Emerson Process Management. The configuration page 140 includes a list 142 of field device blocks allowing a user to select a desired resource block or transducer block within the field device in which the custom digital filter is to be implemented. In the example shown, the user has selected a particular transducer block 144 within the field device. The selected transducer block 144 includes an abnormal situation prevention block implementing a configurable digital filter. The interface page for custom filter design is accessed by selecting the custom filter design tab 146. The configurable parameters of the digital filter type may be selected via the radio buttons 140, 150, 152 in the filter type selection area, and the cut off frequencies, the passband width and the transition width may be entered in the frequency response characteristics fields 154, 156, 158. Note that the various data fields available for entering the various frequency response characteristics of the desired filter may be dependent on the type of filter selected. In the example shown, for instance, a bandpass filter has been selected. Accordingly, the frequency response characteristics fields include the passband center frequency 154, the passband width 156, and the transition width 158. In cases where either a high pass or low pass filter has been selected, only the cut off frequency and the transition width need to be specified.


The method of configuring a digital filter within a field device or other process related equipment described above works well for situations where the filter must only be configured once, such as when the field device is initially installed. However, if circumstances are such that the required filter characteristics may change from time to time, or worse, on a continual basis depending on process conditions, manually configuring the filter over and over again becomes a burden on operators and maintenance personnel. If the required filter characteristics change often, repeatedly accessing the appropriate interface page, entering the modified filter parameters, and reconfiguring the filter can take valuable time away from an operator's more important responsibilities. Such a task becomes impossible if the filter characteristics must be updated on a continuous basis, for example, if the frequency response of the filter is tuned to the speed of a particular piece of rotating equipment and the speed of the rotating equipment is subject to change while the process is running.


This problem may be resolved by implementing the filter design algorithm as a fieldbus function block. In this case, the filter design parameters (filter type, cut off frequency, transition width, etc.) may be exposed to the control system as parameters of the function block. When configured in this way, the filter parameters may be modified directly within the control logic of the process control system (e.g., DeltaV, or the like). For example, in the case were the frequency response characteristics are to be based on the operating speed of a particular piece of rotating equipment, the rotational speed of the equipment may be provided as an input to the function block. The function block may be adapted to select various filter design parameter values appropriate for the received speed value. Of course, the rotational speed of a piece of rotating equipment is just one example of a process variable that may have an impact on the desired frequency response characteristics of a digital filter. It should be clear that substantially any process variable may be employed as a parameter for determining the desired characteristics of the digital filter and provided as an input to a fieldbus function block as described below.


An example of a digital filter design algorithms implemented as a fieldbus function block is shown in FIG. 7. FIG. 7 is an interface page 160 of a process control configuration tool. The process control configuration tool may be, for example, DeltaV Control Studio provided by Emerson Process Management for designing and implementing process control routines for the DeltaV distributed process control system, also provided by Emerson Process Management. The interface page 160 shows an analog input (AI) function block 162, a calculation (calc) function block 168, and an abnormal situation prevention block (abnormal situation prevention Block) 174. The abnormal situation prevention block 174 implements a digital filter design algorithm for determining the coefficients of the digital filter, and applies the digital filter to a process variable data signal received from a field device or other process related equipment. In this example, the AI block 162 provides the rotational speed 164 of Motor 101 in revolutions per minute (rpm). The speed of Motor 101 is received as an input to the calculation block 168. Calculation block 168 calculates the desired center frequency 170 of a bandpass filter based on the speed 164 of Motor 101. For example, the calculation block may calculate the center frequency of the bandpass filter by setting the center frequency equal to a percentage of the received motor speed. Of course, other formulas may be employed for calculating the center frequency of the filter (or the cut-off frequency of the filter in the case of high pass or low pass filters). Additional filter parameters may be set manually as described above. Thus, for the example shown in FIG. 7, the passband width is manually set to 1.1 Hz and the transition width is set to 0.5 Hz. The result is a bandpass filter having a narrow 1.1 Hz passband centered at a frequency determined by the rotational speed of Motor 101.


In addition to calculating the coefficients of the desired digital filter, the Abnormal Situation Prevention block 174 may actually implement the digital filter within the process control routine. For example, the filter may be applied to an input signal associated with a field device or other process related equipment. SPM blocks or other abnormal situation prevention blocks may then analyze the filtered signal to make control decisions based on the status of the filtered process variable data.


Implementing a digital filter design algorithm in an abnormal situation prevention block of a field device or other process related equipment reduces the effort necessary to implement a custom designed digital filter in a process control routine. Only a small number of filter parameters must be exposed to the operator configuring the filter. If desired, process control variables may be input directly into an abnormal situation prevention function block configured to calculate the digital filter coefficients. In this case, the frequency response characteristics may be updated “On-the-fly” as the process is underway. Thus, the frequency response characteristics of the digital filter may be determined by the value of some other process control variable.


The present invention has been described with reference to specific examples. These examples are intended to be illustrative only and should not be read as limiting the invention in any way. It will be apparent to those of ordinary skill in the art that changes, additions, or deletions may be made to the disclosed embodiments without departing from the spirit and scope of the invention.

Claims
  • 1. A system for implementing a digital filter for filtering process variable data, the system comprising: an intelligent device adapted to receive process variable data, implement a digital filter design algorithm, and apply a digital filter to the received process variable data; andan interface adapted to expose digital filter design parameters such that digital filter design parameter values may be provided to the digital filter design algorithm to design a digital filter having desired frequency response characteristics to be applied to the received process variable data.
  • 2. The system for implementing a digital filter of claim 1 wherein the digital filter design algorithm comprises an equiripple filter design algorithm.
  • 3. The system for implementing a digital filter of claim 1 wherein the digital filter design algorithm comprises a Remez Exchange filter design algorithm.
  • 4. The system for implementing a digital filter of claim 1 wherein the digital filter design algorithm comprises a Parks-McClellan filter design algorithm.
  • 5. The system for implementing a digital filter of claim 1 wherein the exposed digital filter design parameters comprise a filter type.
  • 6. The system for implementing a digital filter of claim 5 wherein the filter type comprises one of a highpass or a lowpass filter.
  • 7. The system for implementing a digital filter of claim 6 wherein the exposed filter parameters further comprise a cut-off frequency.
  • 8. The system for implementing a digital filter of claim 5 wherein the filter type comprises a bandpass filter.
  • 9. The system for implementing a digital filter of claim 8 wherein the exposed digital filter design parameters further comprise a passband center frequency and a passband width.
  • 10. The system for implementing a digital filter of claim 8 wherein the exposed digital filter design parameters further comprise a low frequency cut-off frequency and a high-frequency cut off frequency.
  • 11. The system for implementing a digital filter of claim 5 wherein the filter type comprises an infinite impulse response filter.
  • 12. The system for implementing a digital filter of claim 5 wherein the filter type comprises a finite impulse response filter.
  • 13. The system for implementing a digital filter of claim 1, further comprising a communication channel between the intelligent device and the interface.
  • 14. The system for implementing a digital filter of claim 13 wherein the communication channel comprises a communication bus connecting the intelligent device to a computer workstation, the computer or workstation executing an interface application adapted to display the digital filter design parameters on a display device, receive digital filter design parameter values from a user, and forward the received digital filter design parameter values to the intelligent device.
  • 15. The system for implementing the digital filter of claim 13 wherein the communication channel comprises a temporary connection between the intelligent device and a hand held configuration tool.
  • 16. The system for implementing a digital filter of claim 1 wherein the interface comprises a process control variable input, such that at least one frequency response characteristic of the digital filter is determined by a value of the process control variable.
  • 17. The system for implementing a digital filter of claim 1 wherein the intelligent device comprises a process control field device.
  • 18. A process control device comprising: a processor;a memory storing a digital filter design algorithm;a first input adapted to receive digital filter design parameter values for specifying desired frequency response characteristics of a digital filter; anda second input for receiving process variable data;the processor adapted to execute the digital filter design algorithm to create a digital filter having the desired frequency response characteristics, and apply the digital filter to the process variable data.
  • 19. The process control device of claim 18 wherein the digital filter design algorithm comprises an equipple filter design algorithm.
  • 20. The process control device of claim 18 wherein the digital filter design algorithm comprises a Remez Exchange filter design algorithm.
  • 21. The process control device of claim 18 wherein the digital filter design algorithm comprises a Parks-McClellan filter design algorithm.
  • 22. The process control device of claim 18 wherein the digital filter design parameters comprise a filter type.
  • 23. The process control device of claim 22 wherein the filter type comprises one of a low pass filter or a high pass filter.
  • 24. The process control device of claim 23 wherein the filter design parameters further comprise a cut-off frequency.
  • 25. The process control device of claim 23 wherein the filter design parameters further comprise a transition width.
  • 26. The process control device of claim 22 wherein the filter type comprises a bandpass filter.
  • 27. The process control device of claim 26 wherein the filter design parameters further comprise a passband center frequency and a passband width.
  • 28. The process control device of claim 26 wherein the filter design parameters further comprise a low frequency cut off frequency and a high frequency cut off frequency.
  • 29. The process control device of claim 26 wherein the filter design parameters further comprise a transition width.
  • 30. The process control device of claim 18 wherein the first input comprises a communication bus implementing a communication protocol for communicating data between the intelligent process control device and a configuration tool.
  • 31. The process control device of claim 18 wherein the first input comprises a temporary communication link between the intelligent process control device and a hand-held configuration tool.
  • 32. The process control device of claim 18 wherein the first input comprises an operating parameter value associated with the process.
  • 33. The process control device of claim 32 wherein the operating parameter value comprises a process variable value.
  • 34. A method of filtering process variable data comprising: implementing a digital filter design algorithm in a process related control device;exposing one or more filter parameters to an interface whereby filter parameter values may be provided to the digital filter design algorithm;providing filter parameter values to the digital filter design algorithm;calculating digital filter coefficients using the digital filter design algorithm based on the provided filter parameter values; andapplying a digital filter having the calculated digital filter coefficient to the process variable data.
  • 35. The method of claim 34 wherein implementing a digital filter design algorithm comprises implementing a digital filter design algorithm adapted to generate filter coefficients of an infinite impulse response filter.
  • 36. The method of claim 34 wherein implementing a digital filter design algorithm comprises implementing a digital filter design algorithm adapted to generate filter coefficients of a finite impulse response filter.
  • 37. The method of claim 34 wherein implementing a digital filter design algorithm comprises implementing an equiripple filter design algorithm.
  • 38. The method of claim 34 wherein implementing a digital filter design algorithm comprises implementing a Remez Exchange filter design algorithm.
  • 39. The method of claim 34 wherein implementing a digital filter design algorithm comprises implementing a Parks-McClellan filter design algorithm.
  • 40. The method of claim 34 wherein implementing a digital filter design algorithm comprises configuring the digital filter design algorithm in an abnormal situation prevention block associated with a process control device.
  • 41. The method of claim 34 wherein exposing filter parameters comprises exposing a selectable filter type.
  • 42. The method of claim 41 wherein the selectable filter type comprises one of a highpass filter and a lowpass filter.
  • 43. The method of claim 42 wherein exposing filter parameters further comprises exposing a cut-off frequency parameter and a transition width parameter.
  • 44. The method of claim 41 wherein the selectable filter type comprises a bandpass filter.
  • 45. The method of claim 44 wherein exposing filter parameters further comprises exposing a passband center frequency parameter and a passband width parameter.
  • 46. The method of claim 44 wherein exposing filter parameters further comprises exposing a low frequency cut off frequency parameter and a high frequency cut off frequency parameter.
  • 47. The method of claim 44 wherein exposing filter parameters further comprise exposing a transition width parameter.
  • 48. The method of claim 34 wherein exposing filter parameters comprises communicating filter parameters to a configuration tool.
  • 49. The method of claim 48 wherein the configuration tool comprises a software application executed by a computer, and exposing the filter parameters comprises communicating the filter parameters to the computer over a network or bus.
  • 50. The method of claim 48 wherein the communication tool comprises a handheld communicator, and exposing the filter parameters comprises communicating the filter parameters to the handheld communicator over a temporary communication link.
  • 51. The method of claim 48 wherein providing parameter values to the digital filter design algorithm comprises communicating user entered parameter values to the digital filter design algorithm from the configuration tool.
  • 52. The method of claim 34 wherein providing filter parameter values to the digital filter design algorithm comprises providing a process variable value to a process control function block implementing the digital filter design algorithm.
US Referenced Citations (410)
Number Name Date Kind
3096434 King Jul 1963 A
3404264 Kugler Oct 1968 A
3701280 Stroman Oct 1972 A
3705516 Reis Dec 1972 A
3981836 Pangle, Jr. et al. Sep 1976 A
RE29383 Gallatin et al. Sep 1977 E
4058275 Banks et al. Nov 1977 A
4099413 Ohte et al. Jul 1978 A
4322976 Sisson et al. Apr 1982 A
4337516 Murphy et al. Jun 1982 A
4408285 Sisson et al. Oct 1983 A
4425798 Nagai et al. Jan 1984 A
4435770 Shiohata et al. Mar 1984 A
4493042 Shima et al. Jan 1985 A
4517468 Kemper et al. May 1985 A
4527271 Hallee et al. Jul 1985 A
4530234 Cullick et al. Jul 1985 A
4607325 Horn Aug 1986 A
4635214 Kasai et al. Jan 1987 A
4642782 Kemper et al. Feb 1987 A
4644478 Stephens et al. Feb 1987 A
4644749 Somes Feb 1987 A
4649515 Thompson et al. Mar 1987 A
4657179 Aggers et al. Apr 1987 A
4683542 Taniguti et al. Jul 1987 A
4707796 Calabro et al. Nov 1987 A
4734873 Malloy et al. Mar 1988 A
4758964 Bittner et al. Jul 1988 A
4763243 Barlow et al. Aug 1988 A
4764862 Barlow et al. Aug 1988 A
4770543 Burghoff et al. Sep 1988 A
4777585 Kokawa et al. Oct 1988 A
4819233 Delucia et al. Apr 1989 A
4831564 Suga et al. May 1989 A
4843557 Ina et al. Jun 1989 A
4853175 Book, Sr. Aug 1989 A
4858144 Marsaly et al. Aug 1989 A
4873655 Kondraske Oct 1989 A
4885694 Pray et al. Dec 1989 A
4885707 Nichol et al. Dec 1989 A
4907167 Skeirik Mar 1990 A
4910691 Skeirik Mar 1990 A
4922412 Lane et al. May 1990 A
4924418 Bachman et al. May 1990 A
4934196 Romano Jun 1990 A
4942514 Miyagaki et al. Jul 1990 A
4944035 Roger et al. Jul 1990 A
4956793 Bonne et al. Sep 1990 A
4964125 Kim Oct 1990 A
4965742 Skeirik Oct 1990 A
4980844 Demjanenko et al. Dec 1990 A
4992965 Holter et al. Feb 1991 A
5005142 Lipchak et al. Apr 1991 A
5006992 Skeirik Apr 1991 A
5008810 Kessel et al. Apr 1991 A
5015934 Holley et al. May 1991 A
5018215 Nasr et al. May 1991 A
5043862 Takahashi et al. Aug 1991 A
5043863 Bristol et al. Aug 1991 A
5050095 Samad Sep 1991 A
5053815 Wendell Oct 1991 A
5070458 Gilmore et al. Dec 1991 A
5081598 Bellows et al. Jan 1992 A
5089978 Lipner et al. Feb 1992 A
5089984 Struger et al. Feb 1992 A
5094107 Schoch Mar 1992 A
5098197 Shepard et al. Mar 1992 A
5099436 McCown et al. Mar 1992 A
5103409 Shimizu et al. Apr 1992 A
5111531 Grayson et al. May 1992 A
5121467 Skeirik Jun 1992 A
5122976 Bellows et al. Jun 1992 A
5130936 Sheppard et al. Jul 1992 A
5134574 Beaverstock et al. Jul 1992 A
5140530 Guha et al. Aug 1992 A
5142612 Skeirik Aug 1992 A
5148378 Shibayama et al. Sep 1992 A
5158667 Barlow et al. Oct 1992 A
5161013 Rylander et al. Nov 1992 A
5167009 Skeirik Nov 1992 A
5175678 Frerichs et al. Dec 1992 A
5187674 Bonne Feb 1993 A
5189232 Shabtai et al. Feb 1993 A
5193143 Kaemmerer et al. Mar 1993 A
5197114 Skeirik Mar 1993 A
5197328 Fitzgerald Mar 1993 A
5200028 Tatsumi et al. Apr 1993 A
5200958 Hamilton et al. Apr 1993 A
5210704 Husseiny May 1993 A
5212765 Skeirik May 1993 A
5214582 Gray May 1993 A
5224203 Skeirik Jun 1993 A
5228780 Shepard et al. Jul 1993 A
5235527 Ogawa et al. Aug 1993 A
5251151 Demjanenko et al. Oct 1993 A
5258113 Edgerton et al. Nov 1993 A
5265031 Malczewski Nov 1993 A
5265222 Nishiya et al. Nov 1993 A
5274572 O'Neill et al. Dec 1993 A
5282131 Rudd et al. Jan 1994 A
5282261 Skeirik Jan 1994 A
5291190 Scarola et al. Mar 1994 A
5293585 Morita et al. Mar 1994 A
5301101 MacArthur et al. Apr 1994 A
5303181 Stockton Apr 1994 A
5305230 Matsumoto et al. Apr 1994 A
5311421 Nomura et al. May 1994 A
5311447 Bonne May 1994 A
5311562 Palosamy et al. May 1994 A
5315521 Hanson et al. May 1994 A
5317520 Castle May 1994 A
5325522 Vaughn Jun 1994 A
5327357 Feinstein et al. Jul 1994 A
5329443 Bonaquist et al. Jul 1994 A
5333240 Matsumoto et al. Jul 1994 A
5333298 Bland et al. Jul 1994 A
5347449 Meyer et al. Sep 1994 A
5349541 Alexandro, Jr. et al. Sep 1994 A
5351184 Lu et al. Sep 1994 A
5353207 Keeler et al. Oct 1994 A
5353315 Scarola et al. Oct 1994 A
5361612 Voiculescu et al. Nov 1994 A
5369599 Sadjadi et al. Nov 1994 A
5373452 Guha Dec 1994 A
5384698 Jelinek Jan 1995 A
5384699 Levy et al. Jan 1995 A
5386373 Keeler et al. Jan 1995 A
5390287 Obata et al. Feb 1995 A
5390326 Shah Feb 1995 A
5394341 Kepner Feb 1995 A
5394543 Hill et al. Feb 1995 A
5396415 Konar et al. Mar 1995 A
5398303 Tanaka Mar 1995 A
5400246 Wilson et al. Mar 1995 A
5404064 Mermelstein et al. Apr 1995 A
5408406 Mathur et al. Apr 1995 A
5408586 Skeirik Apr 1995 A
5414645 Hirano et al. May 1995 A
5419197 Ogi et al. May 1995 A
5430642 Nakajima et al. Jul 1995 A
5431460 Hass et al. Jul 1995 A
5440478 Fisher et al. Aug 1995 A
5442544 Jelinek Aug 1995 A
5461570 Wang et al. Oct 1995 A
5467355 Umeda et al. Nov 1995 A
5469735 Watanabe et al. Nov 1995 A
5483387 Bauhahn et al. Jan 1996 A
5485753 Burns et al. Jan 1996 A
5486920 Killpatrick et al. Jan 1996 A
5486996 Samad et al. Jan 1996 A
5488697 Kaemmerer et al. Jan 1996 A
5489831 Harris Feb 1996 A
5499188 Kline, Jr. et al. Mar 1996 A
5500941 Gil et al. Mar 1996 A
5504863 Yoshida et al. Apr 1996 A
5511004 Dubost et al. Apr 1996 A
5511442 Tame Apr 1996 A
5519647 DeVille May 1996 A
5521814 Teran et al. May 1996 A
5521842 Yamoda May 1996 A
5528510 Kraft Jun 1996 A
5533413 Kobayashi et al. Jul 1996 A
5537310 Tanake et al. Jul 1996 A
5541833 Bristol et al. Jul 1996 A
5546301 Agrawal et al. Aug 1996 A
5548528 Keeler et al. Aug 1996 A
5552984 Crandall et al. Sep 1996 A
5559690 Keeler et al. Sep 1996 A
5561599 Lu Oct 1996 A
5566065 Hansen et al. Oct 1996 A
5570282 Hansen et al. Oct 1996 A
5570300 Henry et al. Oct 1996 A
5572420 Lu Nov 1996 A
5574638 Lu Nov 1996 A
5586066 White et al. Dec 1996 A
5596704 Geddes et al. Jan 1997 A
5598521 Kilgore et al. Jan 1997 A
5600148 Cole et al. Feb 1997 A
5602757 Haseley et al. Feb 1997 A
5602761 Spoerre et al. Feb 1997 A
5604914 Kabe et al. Feb 1997 A
5606513 Louwagie et al. Feb 1997 A
5610339 Haseley et al. Mar 1997 A
5623598 Voigt et al. Apr 1997 A
5625574 Griffiths et al. Apr 1997 A
5628994 Kaper et al. May 1997 A
5631825 van Weele et al. May 1997 A
5640491 Bhat et al. Jun 1997 A
5640493 Skeirik Jun 1997 A
5646350 Robinson et al. Jul 1997 A
5654841 Hobson et al. Aug 1997 A
5665906 Bayer et al. Sep 1997 A
5666297 Britt et al. Sep 1997 A
5671335 Davis et al. Sep 1997 A
5671351 Wild et al. Sep 1997 A
5675504 Serodes et al. Oct 1997 A
5680409 Qin et al. Oct 1997 A
5682309 Bartusiak et al. Oct 1997 A
5687090 Chen et al. Nov 1997 A
5691895 Kurtzberg et al. Nov 1997 A
5692158 Degeneff et al. Nov 1997 A
5698788 Mol et al. Dec 1997 A
5704011 Hansen et al. Dec 1997 A
5715158 Chen Feb 1998 A
5719767 Jang et al. Feb 1998 A
5729661 Keeler et al. Mar 1998 A
5740324 Mathur et al. Apr 1998 A
5742513 Bouhenguel et al. Apr 1998 A
5753802 Falkler May 1998 A
5754451 Williams May 1998 A
5757371 Oran et al. May 1998 A
5757748 Kiyoura et al. May 1998 A
5761518 Boehling et al. Jun 1998 A
5764891 Warrior Jun 1998 A
5768119 Havekost et al. Jun 1998 A
5777872 He Jul 1998 A
5781432 Keeler et al. Jul 1998 A
5781878 Mizoguchi et al. Jul 1998 A
5790898 Kishima et al. Aug 1998 A
5796602 Wellan et al. Aug 1998 A
5796606 Spring et al. Aug 1998 A
5796609 Tao et al. Aug 1998 A
5798939 Ochoa et al. Aug 1998 A
5803724 Oortwijn et al. Sep 1998 A
5805442 Crater et al. Sep 1998 A
5809490 Guiver et al. Sep 1998 A
5812394 Lewis et al. Sep 1998 A
5819050 Boehling et al. Oct 1998 A
5819232 Shipman Oct 1998 A
5825645 Konar et al. Oct 1998 A
5826249 Skeirik Oct 1998 A
5838561 Owen et al. Nov 1998 A
5842189 Keeler et al. Nov 1998 A
5847952 Samad Dec 1998 A
5848365 Coverdill Dec 1998 A
5855791 Hays et al. Jan 1999 A
5859773 Keeler et al. Jan 1999 A
5859885 Rusnica et al. Jan 1999 A
5859964 Wang et al. Jan 1999 A
5875420 Piety et al. Feb 1999 A
5877954 Klimasauskas et al. Mar 1999 A
5880716 Kunugi et al. Mar 1999 A
5892679 He Apr 1999 A
5892939 Call et al. Apr 1999 A
5898869 Anderson Apr 1999 A
5901058 Steinman et al. May 1999 A
5903455 Sharpe, Jr. et al. May 1999 A
5905989 Biggs May 1999 A
5907701 Hanson May 1999 A
5909370 Lynch Jun 1999 A
5909541 Sampson et al. Jun 1999 A
5909586 Anderson Jun 1999 A
5914875 Monta et al. Jun 1999 A
5918233 La Chance et al. Jun 1999 A
5922963 Piety et al. Jul 1999 A
5924086 Mathur et al. Jul 1999 A
5940290 Dixon Aug 1999 A
5948101 David et al. Sep 1999 A
5949417 Calder Sep 1999 A
5951654 Avsan et al. Sep 1999 A
5960214 Sharpe, Jr. et al. Sep 1999 A
5960441 Bland et al. Sep 1999 A
5975737 Crater et al. Nov 1999 A
5984502 Calder Nov 1999 A
5988847 McLaughlin et al. Nov 1999 A
5995916 Nixon et al. Nov 1999 A
5997167 Crater et al. Dec 1999 A
6006171 Vines et al. Dec 1999 A
6008985 Lake et al. Dec 1999 A
6014598 Duyar et al. Jan 2000 A
6014612 Larson et al. Jan 2000 A
6014876 Taylor Jan 2000 A
6017143 Eryurek et al. Jan 2000 A
6026352 Burns et al. Feb 2000 A
6033257 Lake et al. Mar 2000 A
6035339 Agraharam et al. Mar 2000 A
6038486 Saitoh et al. Mar 2000 A
6041263 Boston et al. Mar 2000 A
6047220 Eryurek Apr 2000 A
6047221 Piche et al. Apr 2000 A
6055483 Lu Apr 2000 A
6061603 Papadopoulos et al. May 2000 A
6067505 Bonoyer et al. May 2000 A
6076124 Korowitz et al. Jun 2000 A
6078843 Shavit Jun 2000 A
6093211 Hamielec et al. Jul 2000 A
6106785 Haviena et al. Aug 2000 A
6108616 Borchers et al. Aug 2000 A
6110214 Klimasauskas Aug 2000 A
6119047 Eryurek et al. Sep 2000 A
6122555 Lu Sep 2000 A
6128279 O'Neil et al. Oct 2000 A
6134032 Kram et al. Oct 2000 A
6134574 Oberman et al. Oct 2000 A
6144952 Keeler et al. Nov 2000 A
6169980 Keeler et al. Jan 2001 B1
6185470 Pado et al. Feb 2001 B1
6197480 Iguchi et al. Mar 2001 B1
6246950 Bessler et al. Jun 2001 B1
6246972 Klimasauskas Jun 2001 B1
6259959 Martin Jul 2001 B1
6266726 Nixon et al. Jul 2001 B1
6298377 Hartikainen et al. Oct 2001 B1
6298454 Schleiss et al. Oct 2001 B1
6317638 Schreder et al. Nov 2001 B1
6317701 Pyotsia et al. Nov 2001 B1
6332110 Wolfe Dec 2001 B1
6387114 Adams May 2002 B2
6389331 Jensen et al. May 2002 B1
6391114 Kirimura et al. May 2002 B1
6397114 Eryurek May 2002 B1
6400681 Bertin et al. Jun 2002 B1
6418465 Hirosawa et al. Jul 2002 B1
6421571 Spriggs et al. Jul 2002 B1
6445963 Blevins et al. Sep 2002 B1
6507797 Kliman et al. Jan 2003 B1
6529780 Soergel et al. Mar 2003 B1
6532392 Eryurek et al. Mar 2003 B1
6535769 Konar et al. Mar 2003 B1
6539267 Eryurek et al. Mar 2003 B1
6549130 Joao Apr 2003 B1
6567718 Campbell et al. May 2003 B1
6571273 Shirai et al. May 2003 B1
6591260 Schwarzhoff et al. Jul 2003 B1
6594589 Coss, Jr. et al. Jul 2003 B1
6601005 Eryurek et al. Jul 2003 B1
6601995 Harrison et al. Aug 2003 B1
6609036 Bickford Aug 2003 B1
6609040 Brunnemann et al. Aug 2003 B1
6615090 Blevins et al. Sep 2003 B1
6628994 Turicchi, Jr. et al. Sep 2003 B1
6633782 Schleiss et al. Oct 2003 B1
6651012 Bechhoefer Nov 2003 B1
6654697 Eryurek et al. Nov 2003 B1
6690274 Bristol Feb 2004 B1
6704689 Hogan et al. Mar 2004 B1
6717513 Sandelman et al. Apr 2004 B1
6721609 Wojsznis Apr 2004 B1
6732191 Baker et al. May 2004 B1
6738388 Stevenson et al. May 2004 B1
6758168 Koskinen et al. Jul 2004 B2
6760782 Swales Jul 2004 B1
6769171 Jung et al. Aug 2004 B2
6774786 Havekost Aug 2004 B1
6813532 Eryurek et al. Nov 2004 B2
6836705 Hellmann et al. Dec 2004 B2
6907383 Eryurek et al. Jun 2005 B2
6965806 Eryurek et al. Nov 2005 B2
7076380 Michel Jul 2006 B2
7079984 Eryurek et al. Jul 2006 B2
7085610 Eryurek et al. Aug 2006 B2
7233834 McDonald, Jr. et al. Jun 2007 B2
20020022894 Eryurek et al. Feb 2002 A1
20020029130 Eryurek et al. Mar 2002 A1
20020038156 Eryurek et al. Mar 2002 A1
20020067370 Forney et al. Jun 2002 A1
20020077711 Nixon et al. Jun 2002 A1
20020107858 Lundahl et al. Aug 2002 A1
20020133320 Wegerich et al. Sep 2002 A1
20020147511 Eryurek et al. Oct 2002 A1
20020161940 Eryurek et al. Oct 2002 A1
20020163427 Eryurek et al. Nov 2002 A1
20030002969 Risser Jan 2003 A1
20030009572 Thurner Jan 2003 A1
20030014226 Loecher et al. Jan 2003 A1
20030014500 Schleiss et al. Jan 2003 A1
20030028268 Eryurek et al. Feb 2003 A1
20030028269 Spriggs et al. Feb 2003 A1
20030065409 Raeth et al. Apr 2003 A1
20030074159 Bechhoefer et al. Apr 2003 A1
20030121330 Muhle et al. Jul 2003 A1
20030172002 Spira et al. Sep 2003 A1
20030195934 Peterson et al. Oct 2003 A1
20030236579 Hauhia et al. Dec 2003 A1
20040052526 Jones et al. Mar 2004 A1
20040064465 Yadav et al. Apr 2004 A1
20040068392 Mylaraswamy Apr 2004 A1
20040075689 Schleiss et al. Apr 2004 A1
20040078171 Wegerich et al. Apr 2004 A1
20040095237 Chen et al. May 2004 A1
20040125487 Sternad et al. Jul 2004 A9
20040158772 Pan et al. Aug 2004 A1
20040181364 Reeves et al. Sep 2004 A1
20040249583 Eryurek et al. Dec 2004 A1
20050007249 Eryurek et al. Jan 2005 A1
20050015624 Ginter et al. Jan 2005 A1
20050060103 Chamness Mar 2005 A1
20050143873 Wilson Jun 2005 A1
20050197792 Haeuptle Sep 2005 A1
20050197803 Eryurek et al. Sep 2005 A1
20050197805 Eryurek et al. Sep 2005 A1
20050197806 Eryurek et al. Sep 2005 A1
20050240289 Hoyte et al. Oct 2005 A1
20050251579 Ngo et al. Nov 2005 A1
20050256601 Lee et al. Nov 2005 A1
20050267709 Heavner et al. Dec 2005 A1
20060020423 Sharpe, Jr. Jan 2006 A1
20060047489 Scheidt et al. Mar 2006 A1
20060052991 Pflugl et al. Mar 2006 A1
20060067388 Sedarat Mar 2006 A1
20060074598 Emigholz et al. Apr 2006 A1
20060114979 Pedersen et al. Jun 2006 A1
20060157029 Suzuki et al. Jul 2006 A1
20060206288 Brahmajosyula et al. Sep 2006 A1
20060265625 Dubois et al. Nov 2006 A1
20070005298 Allen et al. Jan 2007 A1
20070010900 Kavaklioglu et al. Jan 2007 A1
20070097873 Ma et al. May 2007 A1
20070109301 Smith May 2007 A1
20080027678 Miller Jan 2008 A1
Foreign Referenced Citations (79)
Number Date Country
10007757 Apr 1990 CN
1097804 Jan 1995 CN
1267373 Sep 2000 CN
35 40 204 Sep 1986 DE
40 08 560 Sep 1990 DE
44 33 593 Jun 1995 DE
195 02 499 Aug 1996 DE
101 14 206 Nov 2001 DE
102 32 164 Feb 2004 DE
0 122 622 Oct 1984 EP
0 362 386 Apr 1990 EP
0 377 736 Jul 1990 EP
0 413 814 Feb 1991 EP
0 487 419 May 1992 EP
0 581 451 Feb 1994 EP
0 594 227 Apr 1994 EP
0 612 039 Aug 1994 EP
0 624 847 Nov 1994 EP
0 626 697 Nov 1994 EP
0 644 470 Mar 1995 EP
0 715 160 Jun 1996 EP
0 827 096 Mar 1998 EP
0 959 398 Nov 1999 EP
0 961 184 Dec 1999 EP
0 964 325 Dec 1999 EP
0 965 897 Dec 1999 EP
1 630 348 Mar 2006 EP
1 669 827 Jun 2006 EP
2 083 258 Mar 1982 GB
2 294 129 Apr 1996 GB
2 294 793 May 1996 GB
2 347 234 Aug 2000 GB
2 360 357 Sep 2001 GB
2 379 749 Mar 2003 GB
2 380 833 Apr 2003 GB
2 394 312 Apr 2004 GB
05-7138472 Aug 1982 JP
05-033537 Feb 1993 JP
06-242192 Sep 1994 JP
06-331507 Dec 1994 JP
07-127320 May 1995 JP
07-152714 Jun 1995 JP
07-234988 Sep 1995 JP
08-261886 Oct 1996 JP
10-039728 Feb 1998 JP
10-320039 Dec 1998 JP
11-231924 Aug 1999 JP
2000-305620 Nov 2000 JP
2001-016662 Jan 2001 JP
WO-9838585 Sep 1998 WO
WO-9913418 Mar 1999 WO
WO-0017721 Mar 2000 WO
WO-0050851 Aug 2000 WO
WO-0055700 Sep 2000 WO
WO-0062256 Oct 2000 WO
WO-0179947 Oct 2001 WO
WO-0206919 Jan 2002 WO
WO-0223405 Mar 2002 WO
WO-02071168 Sep 2002 WO
WO-02071169 Sep 2002 WO
WO-02071170 Sep 2002 WO
WO-02071171 Sep 2002 WO
WO-02071172 Sep 2002 WO
WO-02071173 Sep 2002 WO
WO-02095509 Nov 2002 WO
WO-02095510 Nov 2002 WO
WO-02095633 Nov 2002 WO
WO-03019304 Mar 2003 WO
WO-03075206 Sep 2003 WO
WO-2005019948 Mar 2005 WO
WO-2005093531 Oct 2005 WO
WO-2005093534 Oct 2005 WO
WO-2005093535 Oct 2005 WO
WO-2006026340 Mar 2006 WO
WO-2006107933 Oct 2006 WO
WO-2007087729 Jun 2007 WO
WO-2008014349 Jan 2008 WO
WO-2008039992 Apr 2008 WO
WO-2008085706 Jul 2008 WO
Related Publications (1)
Number Date Country
20090055457 A1 Feb 2009 US