Writing a DPF operator
Last update: 10.07.2023
Writing a DPF operator
Introduction
The Data Processing Framework (DPF) provides numerical simulation users/engineers with a toolbox for accessing and transforming simulation data. It is used to handle complex pre- or post-processing of simulation data within a simulation workflow.
In DPF, Operators are the main object used to create, transform and stream the data. An operator is composed of a “core” that handles the calculation. It receives the data using input pins, applies a transformation and makes the data available through the output pins (think of an integrated circuit in electronics). There are rules to follow to correctly write operators in a project which is already using DPF.
This section illustrates how to write an operator in a C++ project which is already using DPF capabilities. An operator could also be written in its own plugin.
For a set of instructions on how to create a project from scratch using DPF capabilities to define & expose operators, refer to the Creating a DPF custom operator's library section. For a set of instructions on how to integrate DPF capabilities in already existing project, refer to the Using DPF capabilities in an existing project section.
Operator's implementation example
Custom sort operator
In this example, an operator for custom sorting is implemented.
Note: the corresponding implementation is only employed as an example. Existing "ascending_sort" or "descending_sort" operators are the best way to sort Field data.
Edit the file where the custom operator is implemented and add the following line if it is not already specified:
The custom operator implementation can now start.
The SortOperator structure contains all the implementation related to the custom operator. It contains:
- a name method (unique identifier): "custom_sort"
- a specification method which defines and describes the operator inputs, outputs and data computation. Here, the operator exposes one input named "field_to_sort" at pin 0: when connecting data to this operator, the connect object should be of Field type. It exposes one output named "sorted_field" at pin 0, that is of Field type.
- a run method which contains the data computation code. It first reads the input data, reading the Field provided through input pin 0. It computes the data, sorting it. Then, it creates the output Field and set it as output.
In the specification, the "license" information is optional. If specified, the operator will require a license checkout using the specified increment while running. It will release the license increment once it has been run. Refer to the Using DPF Context section to learn more about licensing in DPF.
Record the operator
The following code enables the operator to be accessible and must be run before any instantiation of this operator.
Working in an operator's library (see Creating a DPF custom operator's library), use the following code:
Working in an existing process (see Using DPF capabilities in an existing project), use the following code:
Instantiate the operator
Once the operator is recorded in the process, it can be instantiated using the following code:
The following can be used to check if the operator is correctly instantiated:
If bIsInstantiated value is false, either the plugin that contains the operator has not been correctly loaded, or the record is not correctly done. The spelling also must be checked.
Use the operator to compute data
The following shows how to create a Field containing the data to be sorted:
Once the operator is instantied and the Field containing the data to sort, is create. The operator can then read the input data and perform the necessary computations.
The output can be requested. It triggers the execution of the operator and provides a Field containing sorted data.
sorted_data
should contain the following values with the following order: 1.5, 2.1, 4.0, 9.5, 10.9.
See the Field documentation to learn how to access the data.
Best practices
- Documentation generation uses JavaScript, **'js' or 'JS' chain of characters must be avoided** in any string object of the operator specification. If this rule is not followed, the documentation generation fails.
- Operator's name should not contain white space and should be written in snake case.
- Use lower case in specification's strings, except for description.
- Spaces must not be used in specification's strings, except for description.
Example full code compiled with Visual Studio on Windows
The following is the complete code showing how to write an operator in an existing process and use it.
It can be compiled on Visual Studio using the VCXPROJ file in Using DPF capabilities in an existing project section.