Data flow
This book has moved to the FINAM documentation. You are viewing an outdated version!
FINAM is based on a hybrid push-pull information flow. Components and adapters "push" data updates to their outputs.
These default outputs (Output
) store the data,
and notify all connected inputs and adapters (targets) that new data is available, but without passing the data itself.
Adapters forward these notifications, until the input of another component is reached.
For details, see Figures 1 and 2.
Figure 1: Simple data flow. Solid: data, dashed: notifications/pulls.
- Model A updates
1a: component pushes data to outputs
1b: outputs forwards notification (w/o effect)- Model B updates
2a: component pulls data from input
2b: input pulls from connected output
2c: data is returned to component
Figure 2: Simple data flow with adapter. Solid: data, dashed: notifications/pulls
- Model A updates
1a: component pushes data to outputs
1b: outputs forwards notification
1c: adapter forwards notification (w/o effect)- Model B updates
2a: component pulls data from input
2b: input pulls from connected adapter
2c: adapter pulls from connected output
2d: adapter transforms data
2e: transformed data is returned to component
Components with time steps are updated by the driver, while components without time steps can update when notified about new data. They are then free to pull data from their inputs. In the most basic case, this pull propagates backwards through the chain of adapters until a component's output is reached, where the latest available data was stored during the push. Adapters handle the data sequentially, and the pulled input returns the transformed data for usage in the component.
The scheduling of the driver ensures that the requested data is always available.
There is one category of adapters that requires a different strategy: those intended for temporal interpolation, aggregation, etc. Such time-dependent adapters need to transform data from multiple points in time to data for one particular requested point in time. For that sake, these adapters do not simply execute their operations during pull. When notified about new input data that became available, the adapter pulls that data and stores it internally. When data is pulled from downstream of the adapter, it does its calculations (e.g. temporal interpolation for the requested point in time) and returns the result. For details, see Figure 3.
Figure 3: Push-based data flow with adapter. Solid: data, dashed: notifications/pulls.
- Model A updates
1a: component pushes data to outputs
1b: outputs forwards notification
1c: adapter pulls and accumulates (or aggregates) data
1d: adapter forwards notification (w/o effect)- Model B updates
2a: component pulls data from input
2b: input pulls from connected adapter
2c: adapter aggregates and returns data
Time-related adapters should still forward notifications, just as usual adapters do.