vecview.h File Reference


Detailed Description

Multivector view module.

This module defines the basic single- and multivector view data structures.

#include <oski/vector.h>

Go to the source code of this file.

Name mangling.

#define oski_vecview_t   MANGLE_(oski_vecview_t)
#define SYMBOLIC_VEC   MANGLE_(SYMBOLIC_VEC)
#define SYMBOLIC_MULTIVEC   MANGLE_(SYMBOLIC_MULTIVEC)
#define oski_CreateVecView   MANGLE_(oski_CreateVecView)
#define oski_CreateMultiVecView   MANGLE_(oski_CreateMultiVecView)
#define oski_DestroyVecView   MANGLE_(oski_DestroyVecView)
#define oski_CopyVecView   MANGLE_(oski_CopyVecView)
#define oski_PrintDebugVecView   MANGLE_(oski_PrintDebugVecView)
#define oski_CalcVecViewInfNorm   MANGLE_(oski_CalcVecViewInfNorm)
#define oski_CalcVecViewInfNormDiff   MANGLE_(oski_CalcVecViewInfNormDiff)
#define oski_InitSubVecView   MANGLE_(oski_InitSubVecView)

Symbolic vector views.

These constants are used by the hint routines (see Set explicit workload hints.).

const oski_vecview_t SYMBOLIC_VEC
 Symbolic single-vector view.
const oski_vecview_t SYMBOLIC_MULTIVEC
 Symbolic multiple-vector view.

Defines

#define INC_OSKI_VECVIEW_H
 oski/vecview.h included.
#define STRIDE_UNIT   ((oski_index_t)1)
 Symbolic constant for "unit stride".

Typedefs

typedef oski_vecstruct_toski_vecview_t
 Multivector view handle.

Functions

oski_vecview_t oski_CreateVecView (oski_value_t *x, oski_index_t length, oski_index_t inc)
 Creates a valid view on a single dense column vector $x$.
oski_vecview_t oski_CreateMultiVecView (oski_value_t *X, oski_index_t length, oski_index_t num_vecs, oski_storage_t orient, oski_index_t stride)
 Creates a multivector view on $k$ dense column vectors $X = \left(\begin{array}{c} x_1 \cdots x_k \end{array}\right)$, stored as a submatrix in the user's data.
int oski_DestroyVecView (oski_vecview_t x)
 Destroy an existing vector view.
oski_vecview_t oski_CopyVecView (const oski_vecview_t x)
 Creates a copy of the given (multi)vector view.
void oski_PrintDebugVecView (const oski_vecview_t x, const char *val_fmt)
 Dump a vector view object to the debug log (FOR DEBUGGING ONLY).
double oski_CalcVecViewInfNorm (const oski_vecview_t x, oski_index_t j)
 Compute the infinity norm of a specified column vector of a vector view.
double oski_CalcVecViewInfNormDiff (const oski_vecview_t x0, oski_index_t j0, const oski_vecview_t x1, oski_index_t j1)
 Compute the infinity norm of the difference between two vectors.
int oski_InitSubVecView (const oski_vecview_t x, oski_index_t i0, oski_index_t j0, oski_index_t R, oski_index_t C, oski_vecstruct_t *y)
 Given an $m\times n$ multivector object $x$, returns a shallow copy submatrix $y = x(i_0:(i_0+R-1), j_0:(j_0+C-1)$.


Function Documentation

double oski_CalcVecViewInfNorm const oski_vecview_t  x,
oski_index_t  j
 

Compute the infinity norm of a specified column vector of a vector view.

Parameters:
[in] x A valid vector view.
[in] j Column for which to compute the infinity norm (in 1-based indices).
Returns:
Let $x_j$ denote column $j$ of $x$. Then this routine returns $||x_j||_\infty$, or -1 on error.

double oski_CalcVecViewInfNormDiff const oski_vecview_t  x0,
oski_index_t  j0,
const oski_vecview_t  x1,
oski_index_t  j1
 

Compute the infinity norm of the difference between two vectors.

Parameters:
[in] x0 A valid vector view.
[in] j0 Column of x0 to use (1-based).
[in] x1 A valid vector view.
[in] j1 Column of x1 to use (1-based).
Returns:
$||x0_{j0} - x1_{j1}||_\infty$, where $x0_{j0}$ is column $j0$ of $x0$, and $x1_{j1}$ is column $j1$ of $x1$. Returns -1 on error.

int oski_InitSubVecView const oski_vecview_t  x,
oski_index_t  i,
oski_index_t  j,
oski_index_t  R,
oski_index_t  C,
oski_vecstruct_t y
 

Given an $m\times n$ multivector object $x$, returns a shallow copy submatrix $y = x(i_0:(i_0+R-1), j_0:(j_0+C-1)$.

Parameters:
[in] x The multivector object, $x$.
[in] i Starting row (1-based index).
[in] j Starting column (1-based index).
[in] R Number of rows in the submatrix, or 0 to include all rows.
[in] C Number of columns in the submatrix, or 0 to include all columns.
[in,out] y Pointer to a structure in which to store the shallow copy of the submatrix.
Returns:
0 on success, or an error code on error.

void oski_PrintDebugVecView const oski_vecview_t  x,
const char *  val_fmt
 

Dump a vector view object to the debug log (FOR DEBUGGING ONLY).

Parameters:
[in] x Vector view object.
[in] val_fmt Format string to use when displaying values.
This format string MUST contain the following fields, in this order: "%f", "%c". That is, the implementation will print a single character to the right of the value. If val_mft is NULL, then the routines uses the default format of "%5.2f%c".

If oski_value_t is complex, then the format string must contain "%f", "%f", and "%c", to display the real and imaginary parts.

The extra fields are used to print special characters to distinguish between values of the logical matrix, and values lying in the "padding" when the stride is not equal to the matrix dimension.


Generated on Wed Sep 19 16:41:23 2007 for BeBOP Optimized Sparse Kernel Interface Library by  doxygen 1.4.6