Developer Guide for Intel® Data Analytics Acceleration Library 2016 Update 4

Batch and Online Processing

Online processing computation mode assumes that the data arrives in blocks i = 1, 2, 3, … nblocks.

Algorithm Input

QR decomposition accepts the input described below. Pass the Input ID as a parameter to the methods that provide input for your algorithm. For more details, see Algorithms.

Input ID

Input

data

Pointer to the numeric table that represents:

  • For batch processing, the entire n x p matrix X to be factorized.
  • For online processing, the ni x p submatrix of X that represents the current data block in the online processing mode. Note that each current data block must have sufficient size: ni > p.

The input can be an object of any class derived from NumericTable.

Algorithm Parameters

QR decomposition has the following parameters:

Parameter

Default Value

Description

algorithmFPType

double

The floating-point type that the algorithm uses for intermediate computations. Can be float or double.

method

defaultDense

Performance-oriented computation method, the only method supported by the algorithm.

Algorithm Output

QR decomposition calculates the results described below. Pass the Result ID as a parameter to the methods that access the results of your algorithm. For more details, see Algorithms.

Result ID

Result

matrixQ

Pointer to the numeric table with the n x p matrix Q1. By default, this result is an object of the HomogenNumericTable class, but you can define the result as an object of any class derived from NumericTable except PackedSymmetricMatrix, PackedTriangularMatrix, and CSRNumericTable.

matrixR

Pointer to the numeric table with the p x p upper triangular matrix R1. By default, this result is an object of the HomogenNumericTable class, but you can define the result as an object of any class derived from NumericTable except the PackedSymmetricMatrix class, CSRNumericTable class, and PackedTriangularMatrix class with the lowerPackedTriangularMatrix layout.

Examples

C++:

Java*: