The invention relates to an automated method for generating program modules, to be used for controlling field devices, from a machine-readable parameterized specification of the field devices, which is used on a control unit to control the field devices, where each of the field devices incorporates control equipment with at least one microprocessor, with at least one electronic storage means and with data input and output means for communications with the control unit.
Devices for measuring and positioning, recording and regulating form the main part of any system for the automation of industrial processes. These devices are referred to collectively as field devices. In the case of measuring devices, they serve in particular to record and report the variables which are central to production, such as pressure, flow rate, level of fullness and temperature. In the case of positioning regulators they often have the functionality of a valve, which makes it is possible to control the flow quantities, either continuously or discretely.
In practice, a distinction is made between two components in the case of the frequently-encountered field measurement devices. The so-called measurement sensors comprise all the equipment and measuring instruments which are required for the creation of a raw measurement result. In the case of a flow-rate meter these might be the measurement tube itself together with measuring probes, for example electrodes, which in some circumstances may be let into the lining of the tube. Connected to these is generally a so-called transducer which, as the second component, essentially serves to carry out the first processing on the output data made available by the measurement sensor. Certain simple signal processing tasks, such as self-monitoring by the system or the calibration and damping of the measured values, can here be carried out even within the field device itself. Apart from this, facilities are commonly also provided in the transducer for remote control of the field device, so that not only can the processed measurement data be passed on but the operating states of the field device can also changed by an external control unit.
This subdivision of the field devices into two parts, on the one hand an executive device (measurement sensor) and on the other hand a transformation device (transducer) is common not only for measurement field devices, but generally for most types of modern field device. Although it would not be necessary to manufacture and market the two components separately, the existence of a transformation device allows one to recognize a critical characteristic of modern field devices: they have a certain level of data processing capacity, and can therefore also be called intelligent field devices.
The particular needs of complex plant structures are reflected in this characteristic. The more diverse and flexible the control options become, on the one hand, and the higher the demands in terms of precision and reliability on the other hand, the greater become the volumes of data necessary for the control of automated systems. In this situation, the bus system used often stands out as the bottleneck, the capacity of which is ultimately solely responsible for the maximum data processing speed achieved. This has resulted in the trend to decentralize data processing as much as possible and to reduce to a minimum the volumes of data transported.
Not least, this decentralization of the data processing poses special demands on the field devices which are used, and also leads to the development of the transformation devices mentioned, such as transducers. Speaking more generally, it is common nowadays to provide control equipment in intelligent field devices: on the one hand this serves to read out, pre-process or generate the electrical output signals from the measuring, regulation or positioning instruments used in the field device. On the other hand, with the help of the control equipment it is possible to establish a link to an internal or external control unit.
For the remote control of field devices, use has long been made of so-called hand-held terminals, which usually communicate with the field devices via the field bus by means of the so-called Hart protocol. However, with increasing frequency computers connected to the field bus are being used, with communications again based on the Hart protocol or alternatively on the more modern Profibus protocols (Profibus-DP, Profibus-PA). In these cases, the links from the computer to the field bus are established via so-called coupling modules.
In order to cover the application areas of modern intelligent field devices, which in some cases are wide-ranging, the remote control devices cited must typically be able to fulfill the following functions. Above all, the objective is to set and change the parameters required for the operation of the field device. The data received from the field device must be checked for plausibility, and it must be possible to compare it with older data. Finally, it is desirable to be able to simulate the behavior of the field device under particular conditions.
Fulfilling these tasks requires that the control unit is provided with certain items of data which represent the characteristics of the field device. This is often effected by means of a machine-readable parameterized description of the field device. A familiar example of such a description is the so-called Device Description Language (DDL). This consists of a list of the variables and menus, to each of which is assigned certain specific attributes for the field device concerned. These variables then specify parameters which are necessary for controlling the field device or for reading out its measured values. The menus describe an operating structure which is either necessary or at least useful for fulfilling the control tasks. The parameterized description thus specified can be read and interpreted directly by the hand-held terminals or PC-based software. This makes it possible for the general control software, which can be used for a multitude of field devices, to be completed with the data for the specific characteristics of a particular field device. The conversion of the parameterized description into an executable control program then does not require any further steps to be undertaken by hand on the control device side.
On the field device side, no such automated conversion of the parameterized description is known in the prior art.
However, here too it is necessary to create program modules which are stored in the control equipment of the field device and which, when they are executed, undertake the necessary control tasks (firmware). Among these program modules it is typically possible to distinguish two blocks. A general analog input block collects together the solutions to various tasks which arise with almost all the different field devices. Such general tasks consist, for example, in interrogating and passing on a damping variable for the impending measurement, in regulating the monitoring of a limiting value, in resealing the data value output by the measurement sensor, and finally in making available a certain default value, for use as the substitute value in the event of a limiting value being incorrectly exceeded, and thereby ensuring that the controlled process can continue to run in safety. A second program module block, called the transducer, brings together all the procedures which are specific to the particular type of field device.
With the solutions available under the prior art, the software in these two blocks must always be created individually in the works by the manufacturer of each new type of field device. In doing this, it is true that in the context of the analog input block the developer can largely build on existing procedures. However, this does not fundamentally prevent the problems, which occur whenever new software is created, from coming to light even in this case. Here, the problems consist not only in the usual requirements for a fault-free, executable and secure program, and one which is well-documented for the purpose of maintenance.
The particular requirement is namely to structure the program modules, which can be executed on the field devices, consistently with the programs in the control units. Inconsistencies between the firmware and control unit can only, if at all, be detected and eliminated with great effort by extensive tests. Because they do not necessarily lead to error messages or system crashes which can be traced, but may possibly simply corrupt the output signal in such a way as to make it exceptionally difficult for staff to determine the cause. If, say, there is a sign error in the program module which undertakes resealing of the data supplied by the sensor, this incorrect measured value will initially be passed over to the control unit. If the incorrect measured value still lies within a theoretically conceivable range, the fault cannot necessarily be spotted, but the operating staff may possibly feel obliged to undertake certain measures to correct the value, which would be unnecessary if the true measured value were known. If the measured value lies outside the conceivable range, then the causes of the error will often be sought initially within the hardware which is being used.
A further disadvantage of this customized development of the firmware consists in the fact that the developer commonly works from a specification of the field device which has been set down in text as the documentation of the characteristics of the field device. The software developer is required in addition to interpret this specification, which almost always involves additional imprecisions and errors.
The prior art thus only describes methods by which the program modules for controlling the control unit, on the one hand, and for the field devices on the other, are created separately from each other. These solutions are obvious, and only appear consistently because the system prerequisites for the two units are different. This applies not only to the hardware components but also, on the one hand, to the operating systems of the hand held terminals or computers, as applicable, or on the other hand to the microprocessors in the field devices.
starting from this prior art, the invention sets as its object the creation of an automated method for generating program modules, for use in controlling field devices, which avoids the need for the independent creation of firmware, and thus prevents in principle the possibility of inconsistencies arising between the program modules for the control units and those of the field devices.
The invention achieves this object by the claims.
This method starts from the machine-readable parameterized description of the field devices which is used on a control unit for controlling the field devices. Such a parameterized description is already known in the prior art and can, as indicated above, generally be interpreted directly by the control programs. In accordance with the invention, the parameters for the field device, contained in the description, and the characteristics relevant for control purposes which are defined by the description, can be identified from the parameters concerned. These are the data type, the size, the set of permitted values or the permitted value range, as appropriate. In addition, for at least one of the identified parameters program modules, which can be executed by the field device's microprocessor, are generated for the field device's control equipment. First, it is possible to generate definition modules, which define for the parameter concerned certain segments of the storage means, the data type and/or the size. Secondly, access modules can also be generated which, for the parameter concerned, regulate the access by the control equipment to the associated storage segment, and which prompt the control equipment to execute other program modules when the parameter is accessed.
The automatic generation of these two types of program modules satisfies the core task of the developer of the firmware. In the field device's storage means, segments are defined which correspond to the particular operating parameter of the field device. Access by the field device's control equipment to the parameter value concerned is then controlled in the access module.
In that the invention is based on a machine-readable parameterized description of the field devices, it falls back on a functional module which the familiar methods produce in any case for each type of field device, and which is put into service on the remote control units. There, such descriptions of the field devices are used to supply the control programs with data and information about the specification of the field device which is to be controlled. In that the invention subsequently analyzes the parameters contained in such descriptions and their attributes which are relevant for control purposes, and from them generates program modules for the field device's control equipment, it renders any separate manual programming of these modules superfluous. In this connection, the advantages of such an automated method for the generation of this firmware lie not only in the time saving and precision achieved in program development. Rather, its use also enables inconsistencies between the control programs involved to be effectively avoided: the program modules which run on the field device's microprocessor are based on the same parameter specification as also underlies the executive program of the control unit.
In an advantageous form of embodiment of the invention it is possible in addition, for at least one parameter, to generate an input checking module which can be called up from the access module when a parameter is changed, to determine whether the parameter value lies within the set of permitted values or within the permitted range, as appropriate. Furthermore, an advantageous possibility is to generate an error message if the parameter value concerned fails this consistency check. It is true that such input checking modules, which check the input of a control value for its consistency, are already frequently provided in the general control software for control units. Here, if there is an erroneous input, an error message can immediately be displayed to the user, who can be required to make a new input. With additional, automatically generated, input checking modules on the field device side itself one initially achieves only additional security. However, these modules reveal their full effectiveness in the context of “standalone operation” of the field device. As has already been indicated above, many field devices are intended not only for operation under remote control, but are provided in addition with a display and input devices, which permit operational states to be set up directly on the field device itself. For this operating mode, the field device and its firmware must themselves undertake the consistency checking on values which have been input, which requires input checking modules of the type cited to be a component part of the firmware.
In another advantageous form of embodiment, a naming module is generated for at least one parameter, to enable a name for the parameter to be stored in the storage means, and the parameter to be accessed under this name. Only when an internal variable name is linked to an explanatory name does user-friendly operation of the field device become possible. It is true that, with a remote controller, such a link can be effected by the software which is executed on the control unit, as is common in the prior art. But in this connection too, the aim must be to enable convenient and user-friendly “standalone operation”.
An example of the invention is explained in more detail below, by reference to the attached diagrams.
In order for the bidirectional data traffic described, between the control units 5 and 6 on the one hand and the field devices 2 and 3 on the other hand, to function it is necessary that the program modules in the devices are matched to each other. In particular, the specifications of each of the field devices, that is the special characteristics of the device type concerned, must be known when the program is being generated. These specifications then provide the parameters required for control purposes, together with their characteristics. For example, for one of the control tasks identified above, the control modules must include a parameter which regulates the damping of the raw measured value. This parameter has certain characteristics: for example, the data which it stores may be of the floating point type with “single” precision. Further, damping may only be permitted in a certain range, the upper and lower limits of which must be specified in the description.
Such descriptions are commonly set down in text form by the developer of the field device, and are interpreted and applied by the programmers of the software which is used in the devices. That is to say, the developer of the device specifies how the damping is to be effected, what the precision and data format must be for the damping parameter which is to be input, and what parameter values are basically permissible.
However, in order to adapt this framework for any particular type of field device, the control computer 6 must provide stored data which reflects the particular specification of the device type. This is done by incorporating a machine-readable parameterized description 13 of the field devices. This consists mainly of a list of parameters which are required to control the field device. Examples of these are the damping, codes for switching the field device on and off, upper and lower limits (which, when the values exceed or fall below them, generate error messages), codes for calibrating the device, together with factors for resealing the data sensed by the intelligent field device. At this point, this list must be made very selectively, because the control of modern field devices requires approximately 100 such parameters. Nowadays, the parameterized description 13 is usually stored in an agreed syntax, called the DDL (Device Description Language). This is directly machine-readable insofar as the sections concerned for the individual parameters can be directly read in 51 and interpreted by the routines of the general part 14 of the software. The description itemized in the DDL is conventionally produced on the basis of a description 15 set down in text form. In this, the developer of a new type of field device gives a comprehensive description of the specification of the new device. To do so, he must at least implicitly go into the parameters cited which are relevant for control purposes, and their characteristics, but may not feel obliged to itemize the description in machine-readable form. Instead, it will much more often be the case that, for example, not all of the characteristics of a parameter will get a mention, because the developer can rightly assume that a reader will be able to supplement these characteristics logically if he is a person skilled in the art and familiar with corresponding equivalent devices.
The conversion of this description 15, set down in text form, into the machine-readable parameterized description 13 is shown in the sketch as the conversion step 16. In practice, this step is subject to numerous sources of error, which result not only from the incompleteness but also from the unavoidable ambiguity of a description in text form. A certain degree of interpretation is always required of the programmer of the DDL 13, as a result of which inaccuracies or even errors can arise in the DDL script. Because DDL in its present familiar form provides a very simple and intuitively comprehensible syntax, many developers of field devices therefore feel obliged to undertake the description in DDL themselves.
For the purpose of performing the control tasks which fall to the intelligent field device 2, certain program modules 11, referred to collectively as firmware, are brought to execution on the microprocessor of the field device 2. The primary purpose served by this firmware is to control and read out from the field device's actuators and sensors 17. However, data, measured values and commands can also be stored here on storage module 18, which likewise belongs to the field device, and processed on the microprocessor in a manner prescribed by the firmware. It is clear that here again separate software must in principle be produced for each type of field device, generated with regard for the hardware components concerned and their functionality.
It is known how to generate 19 this firmware from the description of the field device 15 set down in text form. This program step is also subject to the same uncertainties as the conversion 16 of the text description 15 into the DDL 13. It is indeed true that the programmer of the firmware can fall back on existing (standard) program modules (so-called analog input blocks) for a large proportion of the software which needs to be produced. Equally, he is obliged to take into account, and incorporate into the program modules in the correct place, matters which are specific to the field device, which are laid down in the text format description 15. This familiar method has the following problem: it is essential that there is absolute consistency between the software blocks in the control computer 12 and in the firmware 11. Any disagreement between these program blocks could lead to unforeseeable errors, some of which are exceptionally difficult to track down because they may only come to light under certain operating conditions of the field device or the control computer. The consequence is that, with the familiar prior-art methods, exceptionally comprehensive test phases must be carried out, before the newly-developed software can be considered as error-free, and thereby the field device reaches market-readiness. These problems are fundamentally due to the fact that two interpretation steps 16 and 19 are required, which are independent of each other.
By contrast, the invention proposes a method by which the firmware 11 which is to be newly created is generated directly from the machine-readable parameterized description 13 which is in any case available. This is represented in diagrammatic form in
Here again, the firmware is generated in accordance with the method according to the invention, in step 21. As with the method shown in
As an example of a machine-readable parameterized description,
This application is the US National Stage of International Application No. PCT/EP02/14166, filed Dec. 12, 2002 and claims the benefit thereof. The International Application claims the benefits of U.S. application No. 60/343,701 filed Dec. 27, 2001, both of the applications are incorporated by reference herein in their entirety.
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/EP02/14166 | 12/12/2002 | WO | 7/13/2006 |
Number | Date | Country | |
---|---|---|---|
60343701 | Dec 2001 | US |