Skylark (Sketching Library)  0.1
Public Types | Public Member Functions
skylark::algorithms::regression_solver_t< regression_problem_t< elem::DistMatrix< ValueType, VD, elem::STAR >, linear_tag, l2_tag, no_reg_tag >, elem::DistMatrix< ValueType, VD, elem::STAR >, elem::DistMatrix< ValueType, elem::STAR, elem::STAR >, qr_l2_solver_tag > Class Template Reference

#include <linearl2_regression_solver_Elemental.hpp>

List of all members.

Public Types

typedef ValueType value_type
typedef elem::DistMatrix
< ValueType, VD, elem::STAR > 
matrix_type
typedef elem::DistMatrix
< ValueType, VD, elem::STAR > 
rhs_type
typedef elem::DistMatrix
< ValueType, elem::STAR,
elem::STAR > 
sol_type
typedef regression_problem_t
< matrix_type, linear_tag,
l2_tag, no_reg_tag
problem_type

Public Member Functions

 regression_solver_t (const problem_type &problem)
void solve (const rhs_type &B, sol_type &X) const

Detailed Description

template<typename ValueType, elem::Distribution VD>
class skylark::algorithms::regression_solver_t< regression_problem_t< elem::DistMatrix< ValueType, VD, elem::STAR >, linear_tag, l2_tag, no_reg_tag >, elem::DistMatrix< ValueType, VD, elem::STAR >, elem::DistMatrix< ValueType, elem::STAR, elem::STAR >, qr_l2_solver_tag >

Regression solver for L2 linear regrssion on a dense distributed [VC/VR, STAR] matrix. This implementation uses a QR based approach.

A regression solver accepts a right-hand side and output a solution the the regression problem.

The regression problem is fixed, so it is a parameter of the function constructing the regressoion.

Definition at line 226 of file linearl2_regression_solver_Elemental.hpp.


Member Typedef Documentation

template<typename ValueType , elem::Distribution VD>
typedef elem::DistMatrix<ValueType, VD, elem::STAR> skylark::algorithms::regression_solver_t< regression_problem_t< elem::DistMatrix< ValueType, VD, elem::STAR >, linear_tag, l2_tag, no_reg_tag >, elem::DistMatrix< ValueType, VD, elem::STAR >, elem::DistMatrix< ValueType, elem::STAR, elem::STAR >, qr_l2_solver_tag >::matrix_type

Definition at line 237 of file linearl2_regression_solver_Elemental.hpp.

template<typename ValueType , elem::Distribution VD>
typedef regression_problem_t<matrix_type, linear_tag, l2_tag, no_reg_tag> skylark::algorithms::regression_solver_t< regression_problem_t< elem::DistMatrix< ValueType, VD, elem::STAR >, linear_tag, l2_tag, no_reg_tag >, elem::DistMatrix< ValueType, VD, elem::STAR >, elem::DistMatrix< ValueType, elem::STAR, elem::STAR >, qr_l2_solver_tag >::problem_type

Definition at line 242 of file linearl2_regression_solver_Elemental.hpp.

template<typename ValueType , elem::Distribution VD>
typedef elem::DistMatrix<ValueType, VD, elem::STAR> skylark::algorithms::regression_solver_t< regression_problem_t< elem::DistMatrix< ValueType, VD, elem::STAR >, linear_tag, l2_tag, no_reg_tag >, elem::DistMatrix< ValueType, VD, elem::STAR >, elem::DistMatrix< ValueType, elem::STAR, elem::STAR >, qr_l2_solver_tag >::rhs_type

Definition at line 238 of file linearl2_regression_solver_Elemental.hpp.

template<typename ValueType , elem::Distribution VD>
typedef elem::DistMatrix<ValueType, elem::STAR, elem::STAR> skylark::algorithms::regression_solver_t< regression_problem_t< elem::DistMatrix< ValueType, VD, elem::STAR >, linear_tag, l2_tag, no_reg_tag >, elem::DistMatrix< ValueType, VD, elem::STAR >, elem::DistMatrix< ValueType, elem::STAR, elem::STAR >, qr_l2_solver_tag >::sol_type

Definition at line 239 of file linearl2_regression_solver_Elemental.hpp.

template<typename ValueType , elem::Distribution VD>
typedef ValueType skylark::algorithms::regression_solver_t< regression_problem_t< elem::DistMatrix< ValueType, VD, elem::STAR >, linear_tag, l2_tag, no_reg_tag >, elem::DistMatrix< ValueType, VD, elem::STAR >, elem::DistMatrix< ValueType, elem::STAR, elem::STAR >, qr_l2_solver_tag >::value_type

Definition at line 235 of file linearl2_regression_solver_Elemental.hpp.


Constructor & Destructor Documentation

template<typename ValueType , elem::Distribution VD>
skylark::algorithms::regression_solver_t< regression_problem_t< elem::DistMatrix< ValueType, VD, elem::STAR >, linear_tag, l2_tag, no_reg_tag >, elem::DistMatrix< ValueType, VD, elem::STAR >, elem::DistMatrix< ValueType, elem::STAR, elem::STAR >, qr_l2_solver_tag >::regression_solver_t ( const problem_type problem) [inline]

Prepares the solver to quickly solve given a right-hand side.

Parameters:
problemProblem to solve given right-hand side.

Definition at line 256 of file linearl2_regression_solver_Elemental.hpp.


Member Function Documentation

template<typename ValueType , elem::Distribution VD>
void skylark::algorithms::regression_solver_t< regression_problem_t< elem::DistMatrix< ValueType, VD, elem::STAR >, linear_tag, l2_tag, no_reg_tag >, elem::DistMatrix< ValueType, VD, elem::STAR >, elem::DistMatrix< ValueType, elem::STAR, elem::STAR >, qr_l2_solver_tag >::solve ( const rhs_type B,
sol_type X 
) const [inline]

Solves the regression problem given a multiple right-hand sides.

Parameters:
BRight-hand sides.
XOutput (overwritten).

Definition at line 270 of file linearl2_regression_solver_Elemental.hpp.

References skylark::base::Gemm().

Here is the call graph for this function:


The documentation for this class was generated from the following file: