MADNESS 0.10.1
Classes | Public Types | Public Member Functions | Static Public Member Functions | Public Attributes | Private Types | Private Member Functions | Static Private Member Functions | Private Attributes | Static Private Attributes | List of all members
madness::Exchange< T, NDIM >::ExchangeImpl< T, NDIM > Class Template Reference

#include <exchangeoperator.h>

Collaboration diagram for madness::Exchange< T, NDIM >::ExchangeImpl< T, NDIM >:
Collaboration graph
[legend]

Classes

class  MacroTaskExchangeRow
 
class  MacroTaskExchangeSimple
 

Public Types

typedef Exchange< T, NDIM >::ExchangeAlgorithm Algorithm
 

Public Member Functions

 ExchangeImpl (World &world, const double lo, const double thresh)
 default ctor
 
 ExchangeImpl (World &world, const Nemo *nemo, const int ispin)
 ctor with a nemo calculation
 
 ExchangeImpl (World &world, const SCF *calc, const int ispin)
 ctor with a conventional calculation
 
nlohmann::json gather_statistics () const
 return some statistics about the current settings
 
nlohmann::json gather_timings (World &world) const
 
nlohmann::json get_statistics () const
 
std::shared_ptr< MacroTaskQget_taskq () const
 
Worldget_world () const
 
std::string info () const
 
bool is_symmetric () const
 
vecfuncT operator() (const vecfuncT &vket) const
 apply the exchange operator on a vector of functions
 
void print_timer (World &world) const
 
ExchangeImplset_algorithm (const Algorithm &alg)
 
void set_bra_and_ket (const vecfuncT &bra, const vecfuncT &ket)
 set the bra and ket orbital spaces, and the occupation
 
ExchangeImplset_macro_task_info (const MacroTaskInfo &info)
 
ExchangeImplset_printlevel (const long &level)
 
ExchangeImplset_taskq (std::shared_ptr< MacroTaskQ > taskq1)
 
ExchangeImplsymmetric (const bool flag)
 

Static Public Member Functions

static auto set_poisson (World &world, const double lo, const double econv=FunctionDefaults< 3 >::get_thresh())
 

Public Attributes

Algorithm algorithm_ = multiworld_efficient_row
 
MacroTaskInfo macro_task_info = MacroTaskInfo::preset("default")
 

Private Types

typedef Function< T, NDIMfunctionT
 
typedef std::vector< functionTvecfuncT
 

Private Member Functions

vecfuncT K_large_memory (const vecfuncT &vket, const double mul_tol=0.0) const
 computing the upper triangle of the double sum (over vket and the K orbitals)
 
vecfuncT K_macrotask_efficient (const vecfuncT &vket, const double mul_tol=0.0) const
 exchange using macrotasks, i.e. apply K on a function in individual worlds
 
vecfuncT K_macrotask_efficient_row (const vecfuncT &vket, const double mul_tol=0.0) const
 exchange using macrotasks, i.e. apply K on a function in individual worlds row-wise
 
vecfuncT K_small_memory (const vecfuncT &vket, const double mul_tol=0.0) const
 computing the full square of the double sum (over vket and the K orbitals)
 
bool printdebug () const
 
bool printprogress () const
 
bool printtimings () const
 
bool printtimings_detail () const
 

Static Private Member Functions

static vecfuncT compute_K_tile (World &world, const vecfuncT &mo_bra, const vecfuncT &mo_ket, const vecfuncT &vket, std::shared_ptr< real_convolution_3d > poisson, const bool symmetric, const double mul_tol=0.0)
 computing the upper triangle of the double sum (over vket and the K orbitals)
 
static void reset_timer ()
 

Private Attributes

double lo = 1.e-4
 
vecfuncT mo_bra
 is the exchange matrix symmetric? K phi_i = \sum_k \phi_k \int \phi_k \phi_i
 
vecfuncT mo_ket
 MOs for bra and ket.
 
double mul_tol = FunctionDefaults<NDIM>::get_thresh()*0.1
 
long printlevel = 0
 
nlohmann::json statistics
 statistics of the Cloud (timings, memory) and of the parameters of this run
 
bool symmetric_ = false
 
std::shared_ptr< MacroTaskQtaskq
 
double thresh = FunctionDefaults<NDIM>::get_thresh()
 
Worldworld
 

Static Private Attributes

static std::atomic< long > apply_timer
 
static double elapsed_time
 
static std::atomic< long > mul1_timer
 timing
 
static std::atomic< long > mul2_timer
 

Member Typedef Documentation

◆ Algorithm

template<typename T , std::size_t NDIM>
template<typename T , std::size_t NDIM>
typedef Exchange<T,NDIM>::ExchangeAlgorithm madness::Exchange< T, NDIM >::ExchangeImpl< T, NDIM >::Algorithm

◆ functionT

template<typename T , std::size_t NDIM>
template<typename T , std::size_t NDIM>
typedef Function<T, NDIM> madness::Exchange< T, NDIM >::ExchangeImpl< T, NDIM >::functionT
private

◆ vecfuncT

template<typename T , std::size_t NDIM>
template<typename T , std::size_t NDIM>
typedef std::vector<functionT> madness::Exchange< T, NDIM >::ExchangeImpl< T, NDIM >::vecfuncT
private

Constructor & Destructor Documentation

◆ ExchangeImpl() [1/3]

template<typename T , std::size_t NDIM>
template<typename T , std::size_t NDIM>
madness::Exchange< T, NDIM >::ExchangeImpl< T, NDIM >::ExchangeImpl ( World world,
const double  lo,
const double  thresh 
)
inline

default ctor

◆ ExchangeImpl() [2/3]

template<typename T , std::size_t NDIM>
template<typename T , std::size_t NDIM>
madness::Exchange< T, NDIM >::ExchangeImpl< T, NDIM >::ExchangeImpl ( World world,
const SCF calc,
const int  ispin 
)

◆ ExchangeImpl() [3/3]

template<typename T , std::size_t NDIM>
template<typename T , std::size_t NDIM>
madness::Exchange< T, NDIM >::ExchangeImpl< T, NDIM >::ExchangeImpl ( World world,
const Nemo nemo,
const int  ispin 
)

Member Function Documentation

◆ compute_K_tile()

template<typename T , std::size_t NDIM>
template<typename T , std::size_t NDIM>
std::vector< Function< T, NDIM > > madness::Exchange< T, NDIM >::ExchangeImpl< T, NDIM >::compute_K_tile ( World world,
const vecfuncT mo_bra,
const vecfuncT mo_ket,
const vecfuncT vket,
std::shared_ptr< real_convolution_3d poisson,
const bool  symmetric,
const double  mul_tol = 0.0 
)
staticprivate

◆ gather_statistics()

template<typename T , std::size_t NDIM>
template<typename T , std::size_t NDIM>
nlohmann::json madness::Exchange< T, NDIM >::ExchangeImpl< T, NDIM >::gather_statistics ( ) const
inline

◆ gather_timings()

template<typename T , std::size_t NDIM>
template<typename T , std::size_t NDIM>
nlohmann::json madness::Exchange< T, NDIM >::ExchangeImpl< T, NDIM >::gather_timings ( World world) const
inline

◆ get_statistics()

template<typename T , std::size_t NDIM>
template<typename T , std::size_t NDIM>
nlohmann::json madness::Exchange< T, NDIM >::ExchangeImpl< T, NDIM >::get_statistics ( ) const
inline

◆ get_taskq()

template<typename T , std::size_t NDIM>
template<typename T , std::size_t NDIM>
std::shared_ptr< MacroTaskQ > madness::Exchange< T, NDIM >::ExchangeImpl< T, NDIM >::get_taskq ( ) const
inline

◆ get_world()

template<typename T , std::size_t NDIM>
template<typename T , std::size_t NDIM>
World & madness::Exchange< T, NDIM >::ExchangeImpl< T, NDIM >::get_world ( ) const
inline

◆ info()

template<typename T , std::size_t NDIM>
template<typename T , std::size_t NDIM>
std::string madness::Exchange< T, NDIM >::ExchangeImpl< T, NDIM >::info ( ) const
inline

◆ is_symmetric()

template<typename T , std::size_t NDIM>
template<typename T , std::size_t NDIM>
bool madness::Exchange< T, NDIM >::ExchangeImpl< T, NDIM >::is_symmetric ( ) const
inline

◆ K_large_memory()

template<typename T , std::size_t NDIM>
template<typename T , std::size_t NDIM>
std::vector< Function< T, NDIM > > madness::Exchange< T, NDIM >::ExchangeImpl< T, NDIM >::K_large_memory ( const vecfuncT vket,
const double  mul_tol = 0.0 
) const
private

computing the upper triangle of the double sum (over vket and the K orbitals)

References madness::Exchange< T, NDIM >::is_symmetric(), lo, set_poisson(), and madness::truncate().

◆ K_macrotask_efficient()

template<typename T , std::size_t NDIM>
template<typename T , std::size_t NDIM>
std::vector< Function< T, NDIM > > madness::Exchange< T, NDIM >::ExchangeImpl< T, NDIM >::K_macrotask_efficient ( const vecfuncT vf,
const double  mul_tol = 0.0 
) const
private

exchange using macrotasks, i.e. apply K on a function in individual worlds

apply the exchange operator by tiling the exchange matrix

compute the matrix N_{ik} = N \phi_i \phi_k by tiles, with i,k \in batches A,B, do a local reduce within the tiles: K_{iB} = \sum_{k \in batch B} \phi_k N_{ik} and a universe-wide reduce of the tiles: K\phi_i = \sum_{batches B} K_{iB} saving up to half of the cpu time compared to the naive algorithm

Template Parameters
Tnumber type
NDIMphysical dimension of the argument vket
Parameters
vfargument of the exchange operator
mul_tolcutoff parameter for sparse multiplication
Returns
the exchange operator applied on vket

References madness::Exchange< T, NDIM >::is_symmetric(), lo, madness::Exchange< T, NDIM >::macro_task_info, madness::print(), madness::Exchange< T, NDIM >::set_printlevel(), madness::SCFOperatorBase< T, NDIM >::statistics, and madness::SCFOperatorBase< T, NDIM >::taskq.

◆ K_macrotask_efficient_row()

template<typename T , std::size_t NDIM>
template<typename T , std::size_t NDIM>
std::vector< Function< T, NDIM > > madness::Exchange< T, NDIM >::ExchangeImpl< T, NDIM >::K_macrotask_efficient_row ( const vecfuncT vket,
const double  mul_tol = 0.0 
) const
private

exchange using macrotasks, i.e. apply K on a function in individual worlds row-wise

compute each row of the exchange matrix in different subworlds

References madness::print().

◆ K_small_memory()

template<typename T , std::size_t NDIM>
template<typename T , std::size_t NDIM>
std::vector< Function< T, NDIM > > madness::Exchange< T, NDIM >::ExchangeImpl< T, NDIM >::K_small_memory ( const vecfuncT vket,
const double  mul_tol = 0.0 
) const
private

computing the full square of the double sum (over vket and the K orbitals)

was vtol

was vtol

References madness::apply(), madness::gaxpy(), lo, madness::mul_sparse(), set_poisson(), and madness::truncate().

◆ operator()()

template<typename T , std::size_t NDIM>
template<typename T , std::size_t NDIM>
std::vector< Function< T, NDIM > > madness::Exchange< T, NDIM >::ExchangeImpl< T, NDIM >::operator() ( const vecfuncT vket) const

apply the exchange operator on a vector of functions

note that only one spin is used (either alpha or beta orbitals)

Parameters
[in]vketthe orbitals |i> that the operator is applied on
Returns
a vector of orbitals K| i>

References madness::norm_tree(), and madness::reconstruct().

◆ print_timer()

template<typename T , std::size_t NDIM>
template<typename T , std::size_t NDIM>
void madness::Exchange< T, NDIM >::ExchangeImpl< T, NDIM >::print_timer ( World world) const
inline

◆ printdebug()

template<typename T , std::size_t NDIM>
template<typename T , std::size_t NDIM>
bool madness::Exchange< T, NDIM >::ExchangeImpl< T, NDIM >::printdebug ( ) const
inlineprivate

◆ printprogress()

template<typename T , std::size_t NDIM>
template<typename T , std::size_t NDIM>
bool madness::Exchange< T, NDIM >::ExchangeImpl< T, NDIM >::printprogress ( ) const
inlineprivate

◆ printtimings()

template<typename T , std::size_t NDIM>
template<typename T , std::size_t NDIM>
bool madness::Exchange< T, NDIM >::ExchangeImpl< T, NDIM >::printtimings ( ) const
inlineprivate

◆ printtimings_detail()

template<typename T , std::size_t NDIM>
template<typename T , std::size_t NDIM>
bool madness::Exchange< T, NDIM >::ExchangeImpl< T, NDIM >::printtimings_detail ( ) const
inlineprivate

◆ reset_timer()

template<typename T , std::size_t NDIM>
template<typename T , std::size_t NDIM>
static void madness::Exchange< T, NDIM >::ExchangeImpl< T, NDIM >::reset_timer ( )
inlinestaticprivate

◆ set_algorithm()

template<typename T , std::size_t NDIM>
template<typename T , std::size_t NDIM>
ExchangeImpl & madness::Exchange< T, NDIM >::ExchangeImpl< T, NDIM >::set_algorithm ( const Algorithm alg)
inline

◆ set_bra_and_ket()

template<typename T , std::size_t NDIM>
template<typename T , std::size_t NDIM>
void madness::Exchange< T, NDIM >::ExchangeImpl< T, NDIM >::set_bra_and_ket ( const vecfuncT bra,
const vecfuncT ket 
)
inline

set the bra and ket orbital spaces, and the occupation

Parameters
[in]brabra space, must be provided as complex conjugate
[in]ketket space

References madness::copy().

◆ set_macro_task_info()

template<typename T , std::size_t NDIM>
template<typename T , std::size_t NDIM>
ExchangeImpl & madness::Exchange< T, NDIM >::ExchangeImpl< T, NDIM >::set_macro_task_info ( const MacroTaskInfo info)
inline

◆ set_poisson()

template<typename T , std::size_t NDIM>
template<typename T , std::size_t NDIM>
static auto madness::Exchange< T, NDIM >::ExchangeImpl< T, NDIM >::set_poisson ( World world,
const double  lo,
const double  econv = FunctionDefaults<3>::get_thresh() 
)
inlinestatic

◆ set_printlevel()

template<typename T , std::size_t NDIM>
template<typename T , std::size_t NDIM>
ExchangeImpl & madness::Exchange< T, NDIM >::ExchangeImpl< T, NDIM >::set_printlevel ( const long &  level)
inline

◆ set_taskq()

template<typename T , std::size_t NDIM>
template<typename T , std::size_t NDIM>
ExchangeImpl & madness::Exchange< T, NDIM >::ExchangeImpl< T, NDIM >::set_taskq ( std::shared_ptr< MacroTaskQ taskq1)
inline

◆ symmetric()

template<typename T , std::size_t NDIM>
template<typename T , std::size_t NDIM>
ExchangeImpl & madness::Exchange< T, NDIM >::ExchangeImpl< T, NDIM >::symmetric ( const bool  flag)
inline

Member Data Documentation

◆ algorithm_

template<typename T , std::size_t NDIM>
template<typename T , std::size_t NDIM>
Algorithm madness::Exchange< T, NDIM >::ExchangeImpl< T, NDIM >::algorithm_ = multiworld_efficient_row

◆ apply_timer

template<typename T , std::size_t NDIM>
template<typename T , std::size_t NDIM>
std::atomic<long> madness::Exchange< T, NDIM >::ExchangeImpl< T, NDIM >::apply_timer
inlinestaticprivate

◆ elapsed_time

template<typename T , std::size_t NDIM>
template<typename T , std::size_t NDIM>
double madness::Exchange< T, NDIM >::ExchangeImpl< T, NDIM >::elapsed_time
inlinestaticprivate

◆ lo

template<typename T , std::size_t NDIM>
template<typename T , std::size_t NDIM>
double madness::Exchange< T, NDIM >::ExchangeImpl< T, NDIM >::lo = 1.e-4
private

◆ macro_task_info

template<typename T , std::size_t NDIM>
template<typename T , std::size_t NDIM>
MacroTaskInfo madness::Exchange< T, NDIM >::ExchangeImpl< T, NDIM >::macro_task_info = MacroTaskInfo::preset("default")

◆ mo_bra

template<typename T , std::size_t NDIM>
template<typename T , std::size_t NDIM>
vecfuncT madness::Exchange< T, NDIM >::ExchangeImpl< T, NDIM >::mo_bra
private

is the exchange matrix symmetric? K phi_i = \sum_k \phi_k \int \phi_k \phi_i

Referenced by madness::Exchange< T, NDIM >::ExchangeImpl< T, NDIM >::ExchangeImpl(), and madness::Exchange< T, NDIM >::ExchangeImpl< T, NDIM >::ExchangeImpl().

◆ mo_ket

template<typename T , std::size_t NDIM>
template<typename T , std::size_t NDIM>
vecfuncT madness::Exchange< T, NDIM >::ExchangeImpl< T, NDIM >::mo_ket
private

◆ mul1_timer

template<typename T , std::size_t NDIM>
template<typename T , std::size_t NDIM>
std::atomic<long> madness::Exchange< T, NDIM >::ExchangeImpl< T, NDIM >::mul1_timer
inlinestaticprivate

timing

◆ mul2_timer

template<typename T , std::size_t NDIM>
template<typename T , std::size_t NDIM>
std::atomic<long> madness::Exchange< T, NDIM >::ExchangeImpl< T, NDIM >::mul2_timer
inlinestaticprivate

◆ mul_tol

template<typename T , std::size_t NDIM>
template<typename T , std::size_t NDIM>
double madness::Exchange< T, NDIM >::ExchangeImpl< T, NDIM >::mul_tol = FunctionDefaults<NDIM>::get_thresh()*0.1
private

◆ printlevel

template<typename T , std::size_t NDIM>
template<typename T , std::size_t NDIM>
long madness::Exchange< T, NDIM >::ExchangeImpl< T, NDIM >::printlevel = 0
private

◆ statistics

template<typename T , std::size_t NDIM>
template<typename T , std::size_t NDIM>
nlohmann::json madness::Exchange< T, NDIM >::ExchangeImpl< T, NDIM >::statistics
mutableprivate

statistics of the Cloud (timings, memory) and of the parameters of this run

◆ symmetric_

template<typename T , std::size_t NDIM>
template<typename T , std::size_t NDIM>
bool madness::Exchange< T, NDIM >::ExchangeImpl< T, NDIM >::symmetric_ = false
private

◆ taskq

template<typename T , std::size_t NDIM>
template<typename T , std::size_t NDIM>
std::shared_ptr<MacroTaskQ> madness::Exchange< T, NDIM >::ExchangeImpl< T, NDIM >::taskq
private

◆ thresh

template<typename T , std::size_t NDIM>
template<typename T , std::size_t NDIM>
double madness::Exchange< T, NDIM >::ExchangeImpl< T, NDIM >::thresh = FunctionDefaults<NDIM>::get_thresh()
private

◆ world

template<typename T , std::size_t NDIM>
template<typename T , std::size_t NDIM>
World& madness::Exchange< T, NDIM >::ExchangeImpl< T, NDIM >::world
private

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