COOLFluiD  Release kernel
COOLFluiD is a Collaborative Simulation Environment (CSE) focused on complex MultiPhysics simulations.
Private Attributes | List of all members
EmptyLSSMatrix Class Reference

#include <EmptyLSSMatrix.hpp>

Inherits Matrix.

Public Member Functions

INDIVIDUAL ACCESS
void set_value (const Uint icol, const Uint irow, const Real value)
 Set value at given location in the matrix. More...
 
void add_value (const Uint icol, const Uint irow, const Real value)
 Add value at given location in the matrix. More...
 
void get_value (const Uint icol, const Uint irow, Real &value)
 Get value at given location in the matrix. More...
 
EFFICCIENT ACCESS
void set_values (const BlockAccumulator &values)
 Set a list of values. More...
 
void add_values (const BlockAccumulator &values)
 
void get_values (BlockAccumulator &values)
 Add a list of values. More...
 
void set_row (const Uint iblockrow, const Uint ieq, Real diagval, Real offdiagval)
 Set a row, diagonal and off-diagonals values separately (dirichlet-type boundaries) More...
 
void get_column_and_replace_to_zero (const Uint iblockcol, Uint ieq, std::vector< Real > &values)
 
void symmetric_dirichlet (const Uint blockrow, const Uint ieq, const Real value, Vector &rhs)
 
void tie_blockrow_pairs (const Uint iblockrow_to, const Uint iblockrow_from)
 Add one line to another and tie to it via dirichlet-style (applying periodicity) More...
 
void set_diagonal (const std::vector< Real > &diag)
 Set the diagonal. More...
 
void add_diagonal (const std::vector< Real > &diag)
 Add to the diagonal. More...
 
void get_diagonal (std::vector< Real > &diag)
 Get the diagonal. More...
 
void reset (Real reset_to=0.)
 Reset Matrix. More...
 
MISCELLANEOUS
void print (common::LogStream &stream)
 Print to wherever. More...
 
void print (std::ostream &stream)
 Print to wherever. More...
 
void print (const std::string &filename, std::ios_base::openmode mode=std::ios_base::out)
 Print to file given by filename. More...
 
void print_native (std::ostream &stream)
 Use the native printing functionality of the matrix implementation. More...
 
const bool is_created ()
 Accessor to the state of create. More...
 
const Uint neq ()
 Accessor to the number of equations. More...
 
const Uint blockrow_size ()
 Accessor to the number of block rows. More...
 
const Uint blockcol_size ()
 Accessor to the number of block columns. More...
 
void clone_to (Matrix &other)
 Make a deep copy of the current matrix into other. More...
 
virtual void read_native (const common::URI &file)
 Read in a linear system, optionally filling the provided RHS and solution vector. More...
 
LINEAR ALGEBRA
void apply (const Handle< Vector > &y, const Handle< Vector const > &x, const Real alpha=1., const Real beta=0.)
 Compute y = alpha*A*x + beta*y. More...
 
TEST ONLY
virtual void debug_data (std::vector< Uint > &row_indices, std::vector< Uint > &col_indices, std::vector< Real > &values)
 
- Public Member Functions inherited from Matrix
 Matrix (const std::string &name)
 Default constructor. More...
 
- Public Member Functions inherited from Component
 Component (const std::string &name)
 
virtual ~Component ()
 Virtual destructor. More...
 
const std::string & name () const
 Access the name of the component. More...
 
void rename (const std::string &name)
 Rename the component. More...
 
URI uri () const
 Construct the full path. More...
 
void complete_path (URI &path) const
 
Handle< Componentaccess_component (const URI &path) const
 
Handle< Componentaccess_component_checked (const URI &path)
 
Handle< Component const > access_component_checked (const URI &path) const
 
Handle< Componenthandle ()
 Get a handle to the component. More...
 
Handle< Component const > handle () const
 
template<typename ComponentT >
Handle< ComponentT > handle ()
 
template<typename ComponentT >
Handle< ComponentT const > handle () const
 
Handle< Componentparent () const
 
Handle< Component const > root () const
 
Handle< Componentroot ()
 
Handle< Componentget_child (const std::string &name)
 
Handle< Component const > get_child (const std::string &name) const
 
Handle< Componentget_child_checked (const std::string &name)
 
Handle< Component const > get_child_checked (const std::string &name) const
 
Handle< Componentcreate_component (const std::string &name, const std::string &builder)
 Build a (sub)component of this component using the extended type_name of the component. More...
 
template<typename T >
Handle< T > create_component (const std::string &name)
 Create a (sub)component of this component automatically cast to the specified type. More...
 
template<typename T >
Handle< T > create_static_component (const std::string &name)
 Create a static "always there" subcomponent. More...
 
Componentadd_component (const boost::shared_ptr< Component > &subcomp)
 Add the passed component as a subcomponent. More...
 
void add_link (Component &linked_component)
 
boost::shared_ptr< Componentremove_component (const std::string &name)
 Remove a (sub)component of this component. More...
 
boost::shared_ptr< Componentremove_component (Component &subcomp)
 Remove a (sub)component of this component. More...
 
void clear ()
 Remove all sub-components of this component, except for the static ones. More...
 
void move_to (Component &to_parent)
 
std::string tree (bool basic_mode=false, Uint depth=0, Uint recursion_level=0) const
 
std::string info (const std::string &what=std::string("cospt")) const
 
size_t count_children () const
 
virtual std::string derived_type_name () const =0
 
PropertyListproperties ()
 
const PropertyListproperties () const
 
OptionListoptions ()
 
const OptionListoptions () const
 
void reset_options ()
 Reset all options to their default value. More...
 
void configure_option_recursively (const std::string &optname, const boost::any &val)
 
Componentmark_basic ()
 marks this component as basic. More...
 
template<typename ComponentT >
void put_components (std::vector< boost::shared_ptr< ComponentT > > &vec, const bool recurse)
 
template<typename ComponentT >
void put_components (std::vector< boost::shared_ptr< ComponentT const > > &vec, const bool recurse) const
 
template<>
void put_components (std::vector< boost::shared_ptr< Component > > &vec, const bool recurse)
 
template<>
void put_components (std::vector< boost::shared_ptr< Component const > > &vec, const bool recurse) const
 
Component::iterator begin ()
 The begin iterator for a range containing Components. More...
 
Component::iterator end ()
 The end iterator for a range containing Components. More...
 
Component::const_iterator begin () const
 The begin iterator for a range containing Components (const version) More...
 
Component::const_iterator end () const
 The end iterator for a range containing Components (const version) More...
 
Component::iterator recursive_begin ()
 The begin iterator for a recursive range containing Components. More...
 
Component::iterator recursive_end ()
 The end iterator for a recursive range containing Components. More...
 
Component::const_iterator recursive_begin () const
 The begin iterator for a recursive range containing Components (const version) More...
 
Component::const_iterator recursive_end () const
 The end iterator for a recursive range containing Components (const version) More...
 
template<typename T >
Handle< T > create_component (const std::string &name, const std::string &builder)
 Create a component using the reduced builder name. More...
 
void signal_configure (SignalArgs &args)
 configures all the options on this class More...
 
void signal_create_component (SignalArgs &args)
 creates a component from this component More...
 
void signal_delete_component (SignalArgs &args)
 delete this component More...
 
void signal_move_component (SignalArgs &args)
 moves a component from this component to another More...
 
void signal_list_tree (SignalArgs &args) const
 lists the sub components and puts them on the xml_tree More...
 
void signal_list_tree_recursive (SignalArgs &args) const
 prints tree recursively More...
 
void signal_list_properties (SignalArgs &args) const
 lists the properties of this component More...
 
void signal_list_options (SignalArgs &args) const
 lists the properties of this component More...
 
void signal_list_options_recursive (SignalArgs &args) const
 prints all options recursive More...
 
void signal_list_signals (SignalArgs &args) const
 lists the signals of this component More...
 
void signal_list_signals_recursive (SignalArgs &args) const
 prints all signals recursive More...
 
void signal_print_info (SignalArgs &args) const
 gets info on this component More...
 
void signal_print_tree (SignalArgs &args) const
 signal to print the tree More...
 
void signature_print_tree (SignalArgs &args) const
 signature to signal_print_tree More...
 
void signal_rename_component (SignalArgs &args)
 renames this component More...
 
void signal_save_tree (SignalArgs &args)
 dumps the tree to a file More...
 
void signal_list_content (SignalArgs &args)
 gives information about this component such as options, signals, ... More...
 
void signal_signature (SignalArgs &args)
 Gives a signal signature, if any. More...
 
void signature_create_component (SignalArgs &args)
 
void signature_rename_component (SignalArgs &args)
 
void signature_move_component (SignalArgs &args)
 
void signal_store_timings (SignalArgs &args)
 Signal to store the timings (if enabled) into properties, i.e. for readout from python or the GUI. More...
 
void signal_clear (SignalArgs &args)
 Signal to remove all sub-components. More...
 
void signal_reset_options (SignalArgs &args)
 Signal to set all options to their default value. More...
 
void signal_add_tag (SignalArgs &args)
 Signal to add a tag. More...
 
void signature_add_tag (SignalArgs &args)
 
- Public Member Functions inherited from SignalHandler
 ~SignalHandler ()
 
const storage_tsignal_list () const
 
SignalPtr signal (const SignalID &sname)
 
SignalCPtr signal (const SignalID &sname) const
 
SignalRet call_signal (const SignalID &sname, SignalArgs &sinput)
 Calls the signal by providing its name and input. More...
 
SignalRet call_signal (const SignalID &sname, std::vector< std::string > &sinput)
 Calls the signal by providing its name and input. More...
 
bool signal_exists (const SignalID &sname) const
 Checks if a signal exists or not. More...
 
Signalregist_signal (const SignalID &sname)
 Regist signal. More...
 
void unregist_signal (const SignalID &sname)
 Unregist signal. More...
 
- Public Member Functions inherited from ConnectionManager
 ~ConnectionManager ()
 destructor closes all connections More...
 
Connectionconnection (const std::string &name)
 
Connectionmanage_connection (const std::string &name)
 manages a connection (creates if necessary) More...
 
- Public Member Functions inherited from TaggedObject
 TaggedObject ()
 Constructor. More...
 
bool has_tag (const std::string &tag) const
 
void add_tag (const std::string &tag)
 
std::vector< std::string > get_tags () const
 
void remove_tag (const std::string &tag)
 

Private Attributes

bool m_is_created
 state of creation More...
 
Uint m_neq
 number of equations More...
 
Uint m_blockrow_size
 number of block rows More...
 
Uint m_blockcol_size
 number of block columns More...
 

CREATION, DESTRUCTION AND COMPONENT SYSTEM

static std::string type_name ()
 name of the type More...
 
const std::string solvertype ()
 Accessor to solver type. More...
 
virtual const bool is_swappable (const LSS::Vector &solution, const LSS::Vector &rhs)
 Accessor to the flag if matrix, solution and rhs are tied together or not. More...
 
 EmptyLSSMatrix (const std::string &name)
 Default constructor. More...
 
void create (cf3::common::PE::CommPattern &cp, const Uint neq, const std::vector< Uint > &node_connectivity, const std::vector< Uint > &starting_indices, LSS::Vector &solution, LSS::Vector &rhs, const std::vector< Uint > &periodic_links_nodes=std::vector< Uint >(), const std::vector< bool > &periodic_links_active=std::vector< bool >())
 Setup sparsity structure. More...
 
void create_blocked (common::PE::CommPattern &cp, const VariablesDescriptor &vars, const std::vector< Uint > &node_connectivity, const std::vector< Uint > &starting_indices, Vector &solution, Vector &rhs, const std::vector< Uint > &periodic_links_nodes=std::vector< Uint >(), const std::vector< bool > &periodic_links_active=std::vector< bool >())
 Keep the equations for one variable together, forming big subsystems in the global matrix. More...
 
void destroy ()
 Deallocate underlying data. More...
 

Additional Inherited Members

- Public Types inherited from Component
typedef ComponentIterator< Componentiterator
 type of the iterator to Component More...
 
typedef ComponentIterator< Component const > const_iterator
 type of the iterator to constant Component More...
 
- Public Types inherited from SignalHandler
typedef std::vector< SignalPtrstorage_t
 storage type for signals More...
 
- Static Public Member Functions inherited from Matrix
static std::string type_name ()
 name of the type More...
 
- Static Public Member Functions inherited from Component
static std::string type_name ()
 Get the class name. More...
 
- Public Attributes inherited from SignalHandler
storage_t m_signals
 storage of the signals More...
 
- Protected Member Functions inherited from Component
Componentadd_static_component (const boost::shared_ptr< Component > &subcomp)
 Add a static (sub)component of this component. More...
 
void raise_tree_updated_event ()
 raise event that the path has changed More...
 

Detailed Description

Definition at line 38 of file EmptyLSSMatrix.hpp.

Constructor & Destructor Documentation

EmptyLSSMatrix ( const std::string &  name)

Default constructor.

Definition at line 24 of file EmptyLSSMatrix.cpp.

Member Function Documentation

void add_diagonal ( const std::vector< Real > &  diag)
inlinevirtual

Add to the diagonal.

Implements Matrix.

Definition at line 130 of file EmptyLSSMatrix.hpp.

void add_value ( const Uint  icol,
const Uint  irow,
const Real  value 
)
inlinevirtual

Add value at given location in the matrix.

Implements Matrix.

Definition at line 93 of file EmptyLSSMatrix.hpp.

void add_values ( const BlockAccumulator values)
inlinevirtual

Add a list of values local ibdices eigen, templatization on top level

Implements Matrix.

Definition at line 109 of file EmptyLSSMatrix.hpp.

void apply ( const Handle< Vector > &  y,
const Handle< Vector const > &  x,
const Real  alpha = 1.,
const Real  beta = 0. 
)
inlinevirtual

Compute y = alpha*A*x + beta*y.

Implements Matrix.

Definition at line 182 of file EmptyLSSMatrix.hpp.

const Uint blockcol_size ( )
inlinevirtual

Accessor to the number of block columns.

Implements Matrix.

Definition at line 164 of file EmptyLSSMatrix.hpp.

const Uint blockrow_size ( )
inlinevirtual

Accessor to the number of block rows.

Implements Matrix.

Definition at line 161 of file EmptyLSSMatrix.hpp.

void clone_to ( Matrix other)
inlinevirtual

Make a deep copy of the current matrix into other.

Implements Matrix.

Definition at line 166 of file EmptyLSSMatrix.hpp.

void create ( cf3::common::PE::CommPattern cp,
const Uint  neq,
const std::vector< Uint > &  node_connectivity,
const std::vector< Uint > &  starting_indices,
LSS::Vector solution,
LSS::Vector rhs,
const std::vector< Uint > &  periodic_links_nodes = std::vector<Uint>(),
const std::vector< bool > &  periodic_links_active = std::vector<bool>() 
)
inlinevirtual

Setup sparsity structure.

Implements Matrix.

Definition at line 57 of file EmptyLSSMatrix.hpp.

void create_blocked ( common::PE::CommPattern cp,
const VariablesDescriptor vars,
const std::vector< Uint > &  node_connectivity,
const std::vector< Uint > &  starting_indices,
Vector solution,
Vector rhs,
const std::vector< Uint > &  periodic_links_nodes = std::vector< Uint >(),
const std::vector< bool > &  periodic_links_active = std::vector< bool >() 
)
inlinevirtual

Keep the equations for one variable together, forming big subsystems in the global matrix.

Implements Matrix.

Definition at line 66 of file EmptyLSSMatrix.hpp.

virtual void debug_data ( std::vector< Uint > &  row_indices,
std::vector< Uint > &  col_indices,
std::vector< Real > &  values 
)
inlinevirtual

exports the matrix into big linear arrays

Attention
only for debug and utest purposes

Implements Matrix.

Definition at line 191 of file EmptyLSSMatrix.hpp.

void destroy ( )
inlinevirtual

Deallocate underlying data.

Implements Matrix.

Definition at line 76 of file EmptyLSSMatrix.hpp.

void get_column_and_replace_to_zero ( const Uint  iblockcol,
Uint  ieq,
std::vector< Real > &  values 
)
inlinevirtual

Get a column and replace it to zero (dirichlet-type boundaries, when trying to preserve symmetry) Note that sparsity info is lost, values will contain zeros where no matrix entry is present

Implements Matrix.

Definition at line 119 of file EmptyLSSMatrix.hpp.

void get_diagonal ( std::vector< Real > &  diag)
inlinevirtual

Get the diagonal.

Implements Matrix.

Definition at line 133 of file EmptyLSSMatrix.hpp.

void get_value ( const Uint  icol,
const Uint  irow,
Real &  value 
)
inlinevirtual

Get value at given location in the matrix.

Implements Matrix.

Definition at line 96 of file EmptyLSSMatrix.hpp.

void get_values ( BlockAccumulator values)
inlinevirtual

Add a list of values.

Implements Matrix.

Definition at line 112 of file EmptyLSSMatrix.hpp.

const bool is_created ( )
inlinevirtual

Accessor to the state of create.

Implements Matrix.

Definition at line 155 of file EmptyLSSMatrix.hpp.

virtual const bool is_swappable ( const LSS::Vector solution,
const LSS::Vector rhs 
)
inlinevirtual

Accessor to the flag if matrix, solution and rhs are tied together or not.

Implements Matrix.

Definition at line 51 of file EmptyLSSMatrix.hpp.

const Uint neq ( )
inlinevirtual

Accessor to the number of equations.

Implements Matrix.

Definition at line 158 of file EmptyLSSMatrix.hpp.

void print ( common::LogStream stream)
inlinevirtual

Print to wherever.

Implements Matrix.

Definition at line 144 of file EmptyLSSMatrix.hpp.

void print ( std::ostream &  stream)
inlinevirtual

Print to wherever.

Implements Matrix.

Definition at line 147 of file EmptyLSSMatrix.hpp.

void print ( const std::string &  filename,
std::ios_base::openmode  mode = std::ios_base::out 
)
inlinevirtual

Print to file given by filename.

Implements Matrix.

Definition at line 150 of file EmptyLSSMatrix.hpp.

void print_native ( std::ostream &  stream)
inlinevirtual

Use the native printing functionality of the matrix implementation.

Implements Matrix.

Definition at line 152 of file EmptyLSSMatrix.hpp.

virtual void read_native ( const common::URI file)
inlinevirtual

Read in a linear system, optionally filling the provided RHS and solution vector.

Implements Matrix.

Definition at line 171 of file EmptyLSSMatrix.hpp.

void reset ( Real  reset_to = 0.)
inlinevirtual

Reset Matrix.

Implements Matrix.

Definition at line 136 of file EmptyLSSMatrix.hpp.

void set_diagonal ( const std::vector< Real > &  diag)
inlinevirtual

Set the diagonal.

Implements Matrix.

Definition at line 127 of file EmptyLSSMatrix.hpp.

void set_row ( const Uint  iblockrow,
const Uint  ieq,
Real  diagval,
Real  offdiagval 
)
inlinevirtual

Set a row, diagonal and off-diagonals values separately (dirichlet-type boundaries)

Implements Matrix.

Definition at line 115 of file EmptyLSSMatrix.hpp.

void set_value ( const Uint  icol,
const Uint  irow,
const Real  value 
)
inlinevirtual

Set value at given location in the matrix.

Implements Matrix.

Definition at line 90 of file EmptyLSSMatrix.hpp.

void set_values ( const BlockAccumulator values)
inlinevirtual

Set a list of values.

Implements Matrix.

Definition at line 104 of file EmptyLSSMatrix.hpp.

const std::string solvertype ( )
inlinevirtual

Accessor to solver type.

Implements Matrix.

Definition at line 48 of file EmptyLSSMatrix.hpp.

void symmetric_dirichlet ( const Uint  blockrow,
const Uint  ieq,
const Real  value,
Vector rhs 
)
inlinevirtual

Apply a dirichlet boundary condition, preserving symmetry by moving entries to the RHS

Precondition
The matrix must be structurally symmetric
Warning
Structural symmetry is not checked, incorrect results will appear if you use this on a non structurally symmetric matrix

Implements Matrix.

Definition at line 121 of file EmptyLSSMatrix.hpp.

void tie_blockrow_pairs ( const Uint  iblockrow_to,
const Uint  iblockrow_from 
)
inlinevirtual

Add one line to another and tie to it via dirichlet-style (applying periodicity)

Implements Matrix.

Definition at line 124 of file EmptyLSSMatrix.hpp.

static std::string type_name ( )
inlinestatic

name of the type

Definition at line 45 of file EmptyLSSMatrix.hpp.

Member Data Documentation

Uint m_blockcol_size
private

number of block columns

Definition at line 207 of file EmptyLSSMatrix.hpp.

Uint m_blockrow_size
private

number of block rows

Definition at line 204 of file EmptyLSSMatrix.hpp.

bool m_is_created
private

state of creation

Definition at line 198 of file EmptyLSSMatrix.hpp.

Uint m_neq
private

number of equations

Definition at line 201 of file EmptyLSSMatrix.hpp.


The documentation for this class was generated from the following files:
Send comments to:
COOLFluiD Web Admin