Versions Compared
Key
- This line was added.
- This line was removed.
- Formatting was changed.
...
...
...
...
...
...
...
...
...
...
...
...
...
...
...
...
...
...
...
...
...
...
...
Insert excerpt | ||||||||
---|---|---|---|---|---|---|---|---|
|
This page is for data modellers who need to edit the properties of a pipe.
Overview
A pipe is a connector that links two objects in a PhixFlow model and sends data from the input object to the output object. Pipes allows you to control which attributes and which records from the input are delivered by to the output
...
. With default configuration the pipe pass all attributes and records from the current run.
The pipe must be enabled to
...
For advanced configuration, see Advanced Pipe Configuration.
...
make it active.
For advanced configuration, see Advanced Pipe Configuration.
Tip |
---|
A pipe joining a datasource to a data collector has no details to edit. All the configuration for the output data set occurs in the collector |
...
:
|
...
|
Insert excerpt | ||||||
---|---|---|---|---|---|---|
|
Insert excerpt | ||||||||
---|---|---|---|---|---|---|---|---|
|
Insert excerpt | ||||||
---|---|---|---|---|---|---|
|
Basic Settings
Field | Description | ||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
Name | Enter a name. The name is used to refer to the pipe in other model elements. Pipe names default to The name:
| ||||||||||||||||
Enabled |
| ||||||||||||||||
Static | Normally when a pipe requests data from a non-static input |
...
table, that |
...
table will first attempt to bring itself up to date, generating new |
...
recordsets as necessary, before supplying the data requested. However, if this field is ticked, the input |
...
table will not run. Pipes from collectors cannot be marked as static.
|
...
table, that |
...
table will first attempt to bring itself up to date, generating new |
...
recordsets as necessary, before supplying the data requested.
|
...
table from updating itself. The pipe will pull the existing data from the input |
...
table. Pipes from collectors cannot be marked as static. In the model, hover over a pipe to display an icon that shows | |||||||||||||||||
Mandatory |
|
...
tables are being merged, there must be an input record from this pipe for an output record to be generated by the output |
...
table. If this is a push pipe with positive offsets and this option is ticked then the notification to create another |
...
recordset will only be pushed along the pipe if the last |
...
recordset created contains at least one record. This causes the pipe to present each candidate set to the output |
...
table in a different way than usual. | |||||||||||||||||
Multiplier |
|
...
table, the |
...
table will get a set of records from each of its input pipes. If the multiplier flag is ticked on one of these, then the |
...
table will generate an output record for each record from the set of records provided by the multiplier pipe. For each output record, each of the other input pipes will provide the same set of records as normal. | |
Type | Select:
|
...
|
...
| |
Data to Read | Select the type of input data to use.
|
...
|
...
|
...
|
...
|
...
|
...
|
...
Read Future Data | Use this option to exclude or include input |
...
tables sets that have future dates relative to the |
...
recordset you are generating. For details about how |
...
future recordsets occur, see Managing Future |
...
...
below.
|
...
recordsets from this analysis run. This is the default.
|
...
recordsets in this analysis run. For example, for a |
...
table with Period: Transactional , you will want to include new |
...
recordsets that are being added to the input |
...
table after your analysis run starts |
...
. | |||||||||
Input | Enter the name of the object at the start of the pipe.
| ||||||||
Output | The name of the |
...
table at the end of the pipe. |
Anchor | ||||
---|---|---|---|---|
|
...
Recordsets
In some circumstances the input
...
table may have
...
recordsets that have dates in the future relative to the
...
recordset being generated for the output
...
table. This may happen, for example, if:
- you roll-back some
...
- recordsets on the output
...
- table
- but do not roll-back the corresponding
...
- recordsets on the input
...
- table
- and then request that the output
...
- table is brought up to date.
Some of the
...
recordsets on the input
...
table will have dates in the future relative to some of
...
the recordsets you are rebuilding.
By default, the Read Future Data check box is not ticked. This means pipes ignore any
...
recordsets with dates in the future relative to
...
the recordset you are generating. You want to ignore
...
future recordsets when you rebuild an old
...
recordset, because you want the pipe to retrieve the same data on the rerun as it retrieved when
...
the recordset was first built.
When you run analysis on a
...
table with a transactional period, it is possible that as your analysis is still running, a different run can start and complete. This run can generate
...
additional recordsets on the input
...
table with a future data relative to the date of
...
the recordset you are generating. For transactional input
...
tables, you want the pipe to use these future
...
tables. To do this, tick the Read Future Data check box.
Filter
Filters are made up of a set of clauses; each clause in turn contains a number of conditions. These conditions must be satisfied for data to be passed through the pipe.
Tip |
---|
When the pipe Type is Lookup, the filter controls which data will be cached in memory. |
Field | Description | ||||||
---|---|---|---|---|---|---|---|
Cache Size
| Available when Type is Lookup. The default value is set in System Configuration. For lookup pipes, PhixFlow uses the pipe cache when it looks-up data from |
...
tables or database collectors. For efficiency, the records are cached (stored temporarily in memory) so that if the same set of records need to be looked up again they are readily available without going back to the database. Enter a number to set a limit on the data cache size available for the pipe. You need to estimate the largest number of records that the lookup pipe will return on a single read. Check whether PhixFlow is looking up:
|
...
|
...
If you do not set a limit for the cache, PhixFlow uses the system default set in System Configuration → System Tuning → Maximum Pipe Cache Size.
|
...
|
...
| |
Pipe View | Use this option to look up data from attributes that are present in a |
...
view on the input |
...
table. Select a |
...
view from the list. If the input |
...
table has no views, the list will be empty.
Use the pipe view to limit the attributes that the pipe reads when a |
...
table has lots of attributes containing many data records but you only need data from a few attributes. Only the data for the attributes in the |
...
view are sent to the output |
...
table. Pipe views are very useful:
|
...
To set up a pipe view:
|
...
| |||||||||||||||||
Include History Records |
| ||||||||||||||||
Condition | Select one of the options
To add more conditions, hover your mouse pointer over this field to display the button and add another condition to your filter. | ||||||||||||||||
Clause | Select an option from the list. PhixFlow adds more fields where you can:
|
...
Filter Icons | Hover your mouse pointer over conditions or clauses to display:
| ||||||||||||||||||||||||||||||||
Cache Extraction Filter | A cache extraction filter allows you to further filter the data retrieved by a pipe. These are not commonly used, but are sometimes helpful when either:
For case 1, when using a lookup pipe, data retrieved is stored in a cache. See cache size for details. The cache extraction filter allows you, as you are processing a set of output records, to use different cached entries from the lookup for each of the records are you are processing. This is very fast compared to looking up from the source (i.e. going back to an external DB table or even another PhixFlow |
...
table) for each output record. E.g. you want to look up the credit rating for a customer for a set of transactions - in the output, each transaction is represented by a single output record. You create an indexed lookup pipe using CustNo as the key for the index. This means that for each new CustNo you encounter in the data, all the credit rating entries for that CustNo would be retrieved by the pipe and placed into the cache. The credit rating for each customer is fully historied, so you get a number of entries for each CustNo. To get the relevant lookup entry for each output report (each transaction), you need to compare the transaction date of the output record to the dates of credit rating entries in the cache. So to extract the relevant record, you include a cache extraction filter in the form:
Cache extraction filters are entered free hand. The attribute names referenced must exist in a |
...
table. This means that the each attribute must be one of:
|
...
|
...
|
...
|
...
|
...
|
Filter Examples
Filter on Current User
Sometimes when running analysis you want to select, from the source, only records belonging to the currently logged in user. To set a filter where, say, an attribute in the source Owner
equals the current logged in user, add a condition to the filter like this:
Owner
Equals _user.name
fx
Enter a list of values for an "Is In" or "Is Not In" filter
If you want to based on a list of values, use the Is in or Is not in comparators, then type the list of values into the comparison field as a comma separated list like this:
Country
Is in England, France, Germany
ABC
In this case you must NOT click the ABC icon to convert the value to an fx, because this will indicate that the value is a formula; it must be left as a literal value. If you do click the ABC icon, then the value must be entered like this:
Country
Is in ["England","France","Germany"]
fx
Sort/Group or Order/Index
For lookup pipes this section is called Order/Index.
Use this section to group and sort data as it comes through the pipe. This section has:
- a toolbar with standard buttons
- a grid that lists the attributes that you want to sort or use to group; see Using the Sort/Group Grid, below
- the following below the grid
...
- , when Basic Settings → Type is Look-up:
Field | Description |
---|---|
Maximum Number of records per Group | Available when Type is Look-up, except where the pipe is connected to a calculate table. Enter an upper limit for grouped records. When collating the input records into groups, PhixFlow uses the specified sort order. When it has added the maximum number of records, any more records for the group are ignored. This can be useful if you want the most recent record for an attribute that has many records.
|
Index Type | Available when Type is Look-up. Look-up pipes can be configured for fast "indexed" access to cached data collected from external tables, files or from other |
...
tables. Indexed access is controlled through configuring a pipe with an index and setting index expressions on grouping attributes. If the Type field on the Pipe is set to 'Look-up' then the field "Index Type" becomes available. This can have the value "None" meaning that there are no index keys or "Exact Match", "Best Match" or "Near Match" as described below:
|
Using the Sort/Group
...
Grid
Anchor | ||||
---|---|---|---|---|
|
To add
...
an attribute to the list:
- click
to open the list of attributes in theInsert excerpt _attributes_show _attributes_show nopanel true
...
- input table
- drag
...
- an attribute into the grid.
To remove an attribute, click
Insert excerpt | ||||||
---|---|---|---|---|---|---|
|
To set the sort or group properties for an attribute, double-click its name in the grid. If you want to create a new attribute that is not present in the input
...
table, in the section toolbar, click
Insert excerpt | ||||||
---|---|---|---|---|---|---|
|
Field | Description |
---|---|
Attribute | For input |
...
attributes, PhixFlow displays the attribute name. (Read-only) For a new attribute, enter a name. | |||||||||||||||||
Order | Enter the number for the order the attribute appears in the grid and the order in which it is processed. Other attributes are renumbered. | ||||||||||||||||
Direction | Select the sort order
| ||||||||||||||||
Group |
If this attribute is part of the candidate key set, you must tick the Group check box. Otherwise, the attributes will be used only to sort the data in the candidate set. | ||||||||||||||||
Index Expression | This field is available for lookup pipes with an Index Type option selected. Look-up pipes can be configured for fast "indexed" access to cached data. This data is collected from external tables, files or from other |
...
tables. Indexed access is controlled through configuring a pipe with an index and setting index expressions |
...
on "Group By" attributes here. | |||||||||||
Audit Summary | This option is on the
|
Tip |
---|
In some cases, you may have a pipe connected to a database collector, which pulls data from an external database table. In these cases, the fields in the database must have matching attribute names in the output |
...
table. You can refer to it using the format |
Aggregate
...
Attributes Anchor aggregate aggregate
aggregate | |
aggregate |
Use this section to define the properties of data that you want to combine as it comes through the pipe.
Note |
---|
You cannot aggregate data from attributes if the pipe's input is from: If you need to aggregate data from a database collector, you can use an SQL query. |
This section has:
- a toolbar with standard buttons
- a grid that lists the attributes that you want to aggregate.
Using the Aggregate Attributes Grid
To add
...
an attribute to the list:
- click
to open the list of attributes in theInsert excerpt _attributes_show _attributes_show nopanel true
...
- input table
- drag
...
- an attribute into the grid.
To remove an attribute, click
Insert excerpt | ||||||
---|---|---|---|---|---|---|
|
To set the properties for an aggregate attribute, double-click its name in the grid. PhixFlow opens the attribute's sort properties:
Field | Description |
---|
...
A Function | Select an function to combine |
...
records.
See Aggregate Function for details. Make sure the function matches the data in the attribute. For example, you cannot Sum text. | |
Attribute | Select the |
...
attribute aggregated from the list of attributes in the input |
...
table. PhixFlow does not use the value in this field if the Aggregate Function is Count. | |
Name | Enter the name for the aggregated attribute. This can be the same as the original attribute. |
Order | The order of the aggregate attribute in the output |
...
table. |
Advanced
The following options are available when the pipe Type is Push or Pull. Allow Incomplete Stream Sets is also available when the pipe Type
...
is Lookup.
Field | Description | ||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|
Data Expected |
|
...
|
...
|
...
means PhixFlow reports an error if the pipe receives no data from the input datasource, collector or table during an analysis run. | |||||
Allow Incomplete Streamsets | This field is available when the input is not Transactional. Where the input table is transactional PhixFlow will behave as though the box is ticked.
|
...
|
...
|
...
to complete a recordset before passing the data to the output table. During the analysis run, PhixFlow pulls data into the input table until the recordset is complete. If it cannot complete the recordset, PhixFlow reports an error message. PhixFlow cannot complete a recordset if:
|
...
|
...
|
...
PhixFlow cannot complete a stream set if:
...
Tip |
---|
You must tick this check box on all the pipes that will read from a static (or effectively static) input stream in the analysis run. PhixFlow will report an error if there is any pipe trying to complete the stream set during the analysis run. |
Pipes that are not used in the analysis run do not try to complete a stream set, so will not report an error. (Unused pipes can occur if they lead to streams on branches of the model that are not being run.)
...
Max Records To Read
...
Enter a number for the maximum number of records that should be read down this pipe. The pipe may read more than this number of records if it is configured to carry out multiple reads simultaneously. For example:
- a pipe can be connected to a File Collector that reads multiple files simultaneously
- the pipe strategy is Directed with multiple workers.
...
Select an option to specify how this pipe should be implemented. See the section on Directed Merge Strategy
- Default: this is the way pipes usually works
- Directed: when reading from a large data set; see Using Directed Pipes to Read from Large Data Sets
...
Max Workers
...
This field is available when Strategy is Directed
Enter the maximum number of concurrent worker tasks. When no value is specified, this defaults to 1.
...
This field is available when Strategy is Directed
Enter the number of key values to read for a single worker task, which runs a single select statement.
When no value is specified, this defaults to 1000. This is the maximum value that can be used when reading from an Oracle database.
...
- Pipe Logging: when ticked, PhixFlow always logs the number of records returned by this pipe, whatever is set here.
...
The following properties are available in Basic Settings when you set Data To Read to Custom.
...
Every time the analysis engine runs, all of the stream sets that are created by all of the streams affected by that analysis run are given the same Run ID.
...
Enter the number of stream sets to be retrieved from the input stream.
For a push pipe with positive offsets. enter the maximum number of stream sets that can be created i.e. the maximum number of cycles this pipe can initiate.
...
For example, if:
- the from and to offsets are both 0.0
- and the output stream requires stream generation for the period 17/10/07 - 18/10/07
...
PhixFlow ignores incomplete recordsets in a static input table and does not report an error.
Pipes that are not used in the analysis run do not try to complete a recordset, so will not report an error. (Unused pipes can occur if they lead to tables on branches of the model that are not being run.) | |||||||||
Buffer Size | Enter a number for the buffer size used to perform the table calculation. If a large amount of data is being processed, then setting a large buffer size will give better performance. | ||||||||
Max Records To Read | Enter a number for the maximum number of records that should be read down this pipe. The pipe may read more than this number of records if it is configured to carry out multiple reads simultaneously. For example:
| ||||||||
Strategy | Select an option to specify how this pipe should be implemented. See the section on Directed Merge Strategy
| ||||||||
Max Workers | This field is available when Strategy is Directed Enter the maximum number of concurrent worker tasks. When no value is specified, this defaults to 1. | ||||||||
Worker Size | This field is available when Strategy is Directed Enter the number of key values to read for a single worker task, which runs a single select statement. When no value is specified, this defaults to 1000. This is the maximum value that can be used when reading from an Oracle database. | ||||||||
Log Traffic | When system logging → Pipe Logging is ticked, PhixFlow always logs the number of records returned by this pipe, whatever is set here; see System Logging Configuration.
|
Custom Data to Read
Anchor | ||||
---|---|---|---|---|
|
The following properties are available in Basic Settings when you set Data To Read to Custom.
Field | Description | ||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
Only collect from same run | Every time the analysis engine runs, all of the recordsets that are created by all of the tables affected by that analysis run are given the same Run ID.
| ||||||||||||||||
From Offset | Enter the offset applied to the start of the collection period, relative to the period in the output table that requires populating. | ||||||||||||||||
To Offset | Enter the offset applied to the end of the collection period, relative to the period in the output table that requires populating. | ||||||||||||||||
Max Stream Sets | Enter the number of recordsets to be retrieved from the input table. For a push pipe with positive offsets. enter the maximum number of recordsets that can be created i.e. the maximum number of cycles this pipe can initiate. | ||||||||||||||||
Historied |
For example, if:
the pipe reads data from the input table for the period 17/10/07 - 18/10/07. |
Insert excerpt | ||||||
---|---|---|---|---|---|---|
|
Insert excerpt | ||||||
---|---|---|---|---|---|---|
|
Live Search | ||||||||
---|---|---|---|---|---|---|---|---|
|
Panel | ||||||||||
---|---|---|---|---|---|---|---|---|---|---|
| ||||||||||
|
Learn More
For links to all pages in this topic, see Analysis Models for Batch Processing Data.
Insert excerpt _terms_changing _terms_changing nopanel true