Public Member Functions | Protected Member Functions

Single Class Reference

A 1 x 1 Matrix. More...

#include <keyvalue/value/Single.h>

Inheritance diagram for Single:
Inheritance graph
[legend]

List of all members.

Public Member Functions

 Single ()
 Default constructor sets content to Variant's default.
 Single (const Variant &data)
 Builds and sets content.
template<typename Rhs >
 Single (const Rhs &rhs)
 Builds and sets content.
template<typename Rhs >
Singleoperator= (const Rhs &rhs)
 Assignment operator.
size_t getSize () const
 Gets Vector size.
void resize (size_t size)
 Resizes the vector.
void resize (size_t nRows, size_t nCols)
 Resizes the matrix.
const Variantoperator() (size_t i) const
 Provides access to the i-th element.
Variantoperator() (size_t i)
 Non const operator()().
const Variantoperator() (size_t i, size_t j) const
 Provides access to the element in the i-th row and j-th column.
Variantoperator() (size_t i, size_t j)
 Non const operator()().
void transpose ()
 Transposes the vector.
size_t getNRows () const
 Gets number of rows.
size_t getNCols () const
 Gets number of columns.
bool operator== (const Matrix &rhs) const
 Comparison operator.

Protected Member Functions

void transposeVector ()
 Transposes the matrix if one of its dimensions is 1.

Detailed Description

A 1 x 1 Matrix.

See Matrix documentation for more details.


Constructor & Destructor Documentation

Single (  ) 

Default constructor sets content to Variant's default.

Single ( const Variant data  ) 

Builds and sets content.

Takes type on 1-level-down on the value hierarchy.

Parameters:
data : The content.
Single ( const Rhs &  rhs  ) 

Builds and sets content.

Takes type on 2-or-more-levels-down on the value hierarchy.

Parameters:
rhs : The content.

Member Function Documentation

Single & operator= ( const Rhs &  rhs  ) 

Assignment operator.

Takes type on 2-or-more-levels-down on the value hierarchy.

Parameters:
rhs : The data to be assigned.
Returns:
A reference to this.
size_t getSize (  )  const [inherited]

Gets Vector size.

Returns:
The size.
void resize ( size_t  size  )  [inherited]

Resizes the vector.

The size of a vector can not increase. Debug build check for this and an exception is thrown when the test fails. Release build has undefined behaviour in this case.

Parameters:
size : New size.
Exceptions:
LogicError : (Debug build only) If the new dimension is greater than the original one.
void resize ( size_t  nRows,
size_t  nCols 
) [inherited]

Resizes the matrix.

The size of a matrix (i.e., number of rows times number of columns) can not increase. Debug build check for this and an exception is thrown when the test fails. Release build has undefined behaviour in this case.

The contents of a matrix after resizing is undefined.

Parameters:
nRows : number of rows;
nCols : number of columns.
Exceptions:
LogicError : (Debug build only) If the new size is greater than the original one.
const Variant& operator() ( size_t  i  )  const [inherited]

Provides access to the i-th element.

Debug build performs bound check and throws an exception when the check fail. Release build has undefined behaviour in that circumstance.

Parameters:
i : Element's index.
Returns:
A const reference to the i-th element.
Exceptions:
LogicError : (Debug build only) When i is not smaller than vector's dimension.
Variant& operator() ( size_t  i  )  [inherited]

Non const operator()().

const Variant& operator() ( size_t  i,
size_t  j 
) const [inherited]

Provides access to the element in the i-th row and j-th column.

Debug build perform bound checks and throws an exception on failure. Release build has undefined behaviour in that case.

Parameters:
i : Row index;
j : Column index.
Returns:
A const reference to (i, j)-th element.
Exceptions:
LogicError : (Debug build only) If i is not smaller than the number of rows or j is not smaller than the number of columns.
Variant& operator() ( size_t  i,
size_t  j 
) [inherited]

Non const operator()().

void transpose (  )  [inherited]

Transposes the vector.

size_t getNRows (  )  const [inherited]

Gets number of rows.

Returns:
The number of rows.
size_t getNCols (  )  const [inherited]

Gets number of columns.

Returns:
The number of columns.
bool operator== ( const Matrix rhs  )  const [inherited]

Comparison operator.

Recall that Matrix has reference semantics. Consider the code:

 Matrix m1(2,2);
 m1(0,0) = m1(0,1) = m1(1,0) = m1(1,1) = 1.0;
 Matrix m2(2,2);
 m2(0,0) = m2(0,1) = m2(1,0) = m2(1,1) = 1.0;
 Matrix m3(m1); 

Then m1 == m2 is false and m1 == m3 is true.

Parameters:
rhs : The Value to be compared against.
Returns:
This method returns true if *this and rhs refer to the same data. Otherwise it returns false.
void transposeVector (  )  [protected, inherited]

Transposes the matrix if one of its dimensions is 1.

In-place matrix transposition is a complicated stuff. See

http://en.wikipedia.org/wiki/In-place_matrix_transposition

However, since the storage is linear, the memory layouts of n x 1 and 1 x n matrix, are the same. Hence, we only need to swap dimensions. This method is intent to perform only this simple transposition and it is protected to be called by Vector which derives from this class.

Debug build checks if either of the dimensions is 1 and throws an exception if the test fails. Release build has undefined behaviour in that circumstance.

Exceptions:
LogicError : (Debug build only) If none of dimensions is 1.