Ginkgo
Generated from pipelines/1589998975 branch based on develop. Ginkgo version 1.10.0
A numerical linear algebra library targeting many-core architectures
|
ParIC is an incomplete Cholesky factorization which is computed in parallel. More...
#include <ginkgo/core/factorization/par_ic.hpp>
Classes | |
class | Factory |
struct | parameters_type |
Public Types | |
using | value_type = ValueType |
using | index_type = IndexType |
using | matrix_type = matrix::Csr< ValueType, IndexType > |
Public Types inherited from gko::Composition< ValueType > | |
using | value_type = ValueType |
using | transposed_type = Composition< ValueType > |
Public Types inherited from gko::EnablePolymorphicAssignment< Composition< ValueType > > | |
using | result_type = Composition< ValueType > |
Public Types inherited from gko::ConvertibleTo< Composition< ValueType > > | |
using | result_type = Composition< ValueType > |
Public Member Functions | |
std::shared_ptr< const matrix_type > | get_l_factor () const |
std::shared_ptr< const matrix_type > | get_lt_factor () const |
const parameters_type & | get_parameters () const |
Public Member Functions inherited from gko::Composition< ValueType > | |
const std::vector< std::shared_ptr< const LinOp > > & | get_operators () const noexcept |
Returns a list of operators of the composition. More... | |
std::unique_ptr< LinOp > | transpose () const override |
Returns a LinOp representing the transpose of the Transposable object. More... | |
std::unique_ptr< LinOp > | conj_transpose () const override |
Returns a LinOp representing the conjugate transpose of the Transposable object. More... | |
Composition & | operator= (const Composition &) |
Copy-assigns a Composition. More... | |
Composition & | operator= (Composition &&) |
Move-assigns a Composition. More... | |
Composition (const Composition &) | |
Copy-constructs a Composition. More... | |
Composition (Composition &&) | |
Move-constructs a Composition. More... | |
Public Member Functions inherited from gko::EnableLinOp< Composition< ValueType > > | |
const Composition< ValueType > * | apply (ptr_param< const LinOp > b, ptr_param< LinOp > x) const |
Composition< ValueType > * | apply (ptr_param< const LinOp > b, ptr_param< LinOp > x) |
const Composition< ValueType > * | apply (ptr_param< const LinOp > alpha, ptr_param< const LinOp > b, ptr_param< const LinOp > beta, ptr_param< LinOp > x) const |
Composition< ValueType > * | apply (ptr_param< const LinOp > alpha, ptr_param< const LinOp > b, ptr_param< const LinOp > beta, ptr_param< LinOp > x) |
Public Member Functions inherited from gko::EnableAbstractPolymorphicObject< Composition< ValueType >, LinOp > | |
std::unique_ptr< Composition< ValueType > > | create_default (std::shared_ptr< const Executor > exec) const |
std::unique_ptr< Composition< ValueType > > | create_default () const |
std::unique_ptr< Composition< ValueType > > | clone (std::shared_ptr< const Executor > exec) const |
std::unique_ptr< Composition< ValueType > > | clone () const |
Composition< ValueType > * | copy_from (const PolymorphicObject *other) |
std::enable_if_t< std::is_base_of< PolymorphicObject, std::decay_t< Derived > >::value, Composition< ValueType > > * | copy_from (std::unique_ptr< Derived > &&other) |
std::enable_if_t< std::is_base_of< PolymorphicObject, std::decay_t< Derived > >::value, Composition< ValueType > > * | copy_from (const std::unique_ptr< Derived > &other) |
Composition< ValueType > * | copy_from (const std::shared_ptr< const PolymorphicObject > &other) |
Composition< ValueType > * | move_from (ptr_param< PolymorphicObject > other) |
Composition< ValueType > * | clear () |
Public Member Functions inherited from gko::LinOp | |
LinOp * | apply (ptr_param< const LinOp > b, ptr_param< LinOp > x) |
Applies a linear operator to a vector (or a sequence of vectors). More... | |
const LinOp * | apply (ptr_param< const LinOp > b, ptr_param< LinOp > x) const |
LinOp * | apply (ptr_param< const LinOp > alpha, ptr_param< const LinOp > b, ptr_param< const LinOp > beta, ptr_param< LinOp > x) |
Performs the operation x = alpha * op(b) + beta * x. More... | |
const LinOp * | apply (ptr_param< const LinOp > alpha, ptr_param< const LinOp > b, ptr_param< const LinOp > beta, ptr_param< LinOp > x) const |
const dim< 2 > & | get_size () const noexcept |
Returns the size of the operator. More... | |
virtual bool | apply_uses_initial_guess () const |
Returns true if the linear operator uses the data given in x as an initial guess. More... | |
LinOp & | operator= (const LinOp &)=default |
Copy-assigns a LinOp. More... | |
LinOp & | operator= (LinOp &&other) |
Move-assigns a LinOp. More... | |
LinOp (const LinOp &)=default | |
Copy-constructs a LinOp. More... | |
LinOp (LinOp &&other) | |
Move-constructs a LinOp. More... | |
Public Member Functions inherited from gko::EnableAbstractPolymorphicObject< LinOp > | |
std::unique_ptr< LinOp > | create_default (std::shared_ptr< const Executor > exec) const |
std::unique_ptr< LinOp > | create_default () const |
std::unique_ptr< LinOp > | clone (std::shared_ptr< const Executor > exec) const |
std::unique_ptr< LinOp > | clone () const |
LinOp * | copy_from (const PolymorphicObject *other) |
std::enable_if_t< std::is_base_of< PolymorphicObject, std::decay_t< Derived > >::value, LinOp > * | copy_from (std::unique_ptr< Derived > &&other) |
std::enable_if_t< std::is_base_of< PolymorphicObject, std::decay_t< Derived > >::value, LinOp > * | copy_from (const std::unique_ptr< Derived > &other) |
LinOp * | copy_from (const std::shared_ptr< const PolymorphicObject > &other) |
LinOp * | move_from (ptr_param< PolymorphicObject > other) |
LinOp * | clear () |
Public Member Functions inherited from gko::PolymorphicObject | |
PolymorphicObject & | operator= (const PolymorphicObject &) |
std::unique_ptr< PolymorphicObject > | create_default (std::shared_ptr< const Executor > exec) const |
Creates a new "default" object of the same dynamic type as this object. More... | |
std::unique_ptr< PolymorphicObject > | create_default () const |
Creates a new "default" object of the same dynamic type as this object. More... | |
std::unique_ptr< PolymorphicObject > | clone (std::shared_ptr< const Executor > exec) const |
Creates a clone of the object. More... | |
std::unique_ptr< PolymorphicObject > | clone () const |
Creates a clone of the object. More... | |
PolymorphicObject * | copy_from (const PolymorphicObject *other) |
Copies another object into this object. More... | |
template<typename Derived , typename Deleter > | |
std::enable_if_t< std::is_base_of< PolymorphicObject, std::decay_t< Derived > >::value, PolymorphicObject > * | copy_from (std::unique_ptr< Derived, Deleter > &&other) |
Moves another object into this object. More... | |
template<typename Derived , typename Deleter > | |
std::enable_if_t< std::is_base_of< PolymorphicObject, std::decay_t< Derived > >::value, PolymorphicObject > * | copy_from (const std::unique_ptr< Derived, Deleter > &other) |
Copies another object into this object. More... | |
PolymorphicObject * | copy_from (const std::shared_ptr< const PolymorphicObject > &other) |
Copies another object into this object. More... | |
PolymorphicObject * | move_from (ptr_param< PolymorphicObject > other) |
Moves another object into this object. More... | |
PolymorphicObject * | clear () |
Transforms the object into its default state. More... | |
std::shared_ptr< const Executor > | get_executor () const noexcept |
Returns the Executor of the object. More... | |
Public Member Functions inherited from gko::log::EnableLogging< PolymorphicObject > | |
void | add_logger (std::shared_ptr< const Logger > logger) override |
void | remove_logger (const Logger *logger) override |
void | remove_logger (ptr_param< const Logger > logger) |
const std::vector< std::shared_ptr< const Logger > > & | get_loggers () const override |
void | clear_loggers () override |
Public Member Functions inherited from gko::log::Loggable | |
void | remove_logger (ptr_param< const Logger > logger) |
Public Member Functions inherited from gko::EnablePolymorphicAssignment< Composition< ValueType > > | |
void | convert_to (result_type *result) const override |
Converts the implementer to an object of type result_type. More... | |
void | move_to (result_type *result) override |
Converts the implementer to an object of type result_type by moving data from this object. More... | |
Public Member Functions inherited from gko::ConvertibleTo< Composition< ValueType > > | |
void | convert_to (ptr_param< result_type > result) const |
void | move_to (ptr_param< result_type > result) |
Static Public Member Functions | |
template<typename... Args> | |
static std::unique_ptr< Composition< ValueType > > | create (Args &&... args)=delete |
static auto | build () -> decltype(Factory ::create()) |
static parameters_type | parse (const config::pnode &config, const config::registry &context, const config::type_descriptor &td_for_child=config::make_type_descriptor< ValueType, IndexType >()) |
Create the parameters from the property_tree. More... | |
Static Public Member Functions inherited from gko::EnableCreateMethod< Composition< ValueType > > | |
static std::unique_ptr< Composition< ValueType > > | create (Args &&... args) |
ParIC is an incomplete Cholesky factorization which is computed in parallel.
is a lower triangular matrix, which approximates a given matrix with . Here, has the same sparsity pattern as , which is also called IC(0).
The ParIC algorithm generates the incomplete factors iteratively, using a fixed-point iteration of the form
In general, the entries of can be iterated in parallel and in asynchronous fashion, the algorithm asymptotically converges to the incomplete factors and fulfilling where is the pre-defined sparsity pattern (in case of IC(0) the sparsity pattern of the system matrix ). The number of ParIC sweeps needed for convergence depends on the parallelism level: For sequential execution, a single sweep is sufficient, for fine-grained parallelism, the number of sweeps necessary to get a good approximation of the incomplete factors depends heavily on the problem. On the OpenMP executor, 3 sweeps usually give a decent approximation in our experiments, while GPU executors can take 10 or more iterations.
The ParIC algorithm in Ginkgo follows the design of E. Chow and A. Patel, Fine-grained Parallel Incomplete LU Factorization, SIAM Journal on Scientific Computing, 37, C169-C193 (2015).
ValueType | Type of the values of all matrices used in this class |
IndexType | Type of the indices of all matrices used in this class |
|
static |
Create the parameters from the property_tree.
Because this is directly tied to the specific type, the value/index type settings within config are ignored and type_descriptor is only used for children configs.
config | the property tree for setting |
context | the registry |
td_for_child | the type descriptor for children configs. The default uses the value/index type of this class. |