10#ifndef CCSTRUCTURES_H_
11#define CCSTRUCTURES_H_
81 ss <<
"memory usage of process "<< world.
rank()<<
" on "<< hostname<<
": "<<
mem/1024/1024<<
"MB";
82 std::string msg=
ss.str();
105 output(
const std::string& msg)
const;
108 section(
const std::string& msg)
const;
114 warning(
const std::string& msg)
const;
122 using madness::operators::operator<<;
160 info(
const bool debug =
true,
const double norm = 12345.6789);
203 std::cout << std::setfill(
' ') << std::scientific << std::setprecision(2)
204 <<
"Timer: " <<
times.first <<
" (Wall), " <<
times.second <<
" (CPU)" <<
", (" +
operation +
")"
233 initialize < std::string > (
"calc_type",
"mp2",
"the calculation type", {
"mp2",
"mp3",
"cc2",
"cis",
"lrcc2",
"cispd",
"adc2",
"test"});
278 (
"excitations", {},
"vector containing the excitations");
285 if (value ==
"mp2")
return CT_MP2;
286 if (value ==
"mp3")
return CT_MP3;
287 if (value ==
"cc2")
return CT_CC2;
288 if (value ==
"cis")
return CT_LRCCS;
289 if (value ==
"lrcc2")
return CT_LRCC2;
290 if (value ==
"cispd")
return CT_CISPD;
291 if (value ==
"adc2")
return CT_ADC2;
292 if (value ==
"test")
return CT_TEST;
382 if (world.
rank() == 0)
383 std::cout <<
"\n\n\n\n\n!!!!!!!!!\n\nERROR IN CC_PARAMETERS:\n ERROR MESSAGE IS: " << msg
384 <<
"\n\n\n!!!!!!!!" << std::endl;
389 if (world.
rank() == 0) std::cout <<
"WARNING IN CC_PARAMETERS!: " << msg << std::endl;
397 std::vector<std::pair<int, int>>
map;
402 std::vector<std::pair<int, int>>
map;
403 for (
int i=
nfreeze; i<nocc; ++i) {
404 for (
int j=i; j<nocc; ++j) {
405 map.push_back(std::make_pair(i,j));
412 std::vector<std::pair<int, int>>
map;
413 for (
int i=
nfreeze; i<nocc; ++i) {
414 for (
int j=
nfreeze; j<nocc; ++j) {
415 map.push_back(std::make_pair(i,j));
421 void print(
const std::string msg=
"PairVectorMap")
const {
424 for (
size_t i=0; i<
map.size(); ++i) {
443 template<
typename R,
typename opT>
446 for (
auto&
p :
arg.allpairs) {
448 int j=
p.first.second;
456 for (
int i=0; i<
argument.size(); ++i) {
463 std::vector<T> vector;
464 for (
size_t i=0; i<
argument.allpairs.size(); ++i) {
472 return allpairs.at(std::make_pair(i, j));
480 return allpairs[std::make_pair(i, j)];
486 std::pair<int, int> key = std::make_pair(i, j);
496 if (
allpairs.size() == 0)
return true;
502template <
typename T, std::
size_t NDIM>
509template<
typename T, std::
size_t NDIM>
513 for (
const auto&
tmp :
im.allpairs) {
530 for (
size_t i = 0; i <
v.size(); i++) {
537 for (
size_t i = 0; i <
v.size(); i++) {
544 for (
size_t i = 0; i <
v.size(); i++) {
554 for (
size_t i = 0; i <
v.size(); i++) {
562 for (
auto x:
v)
functions.insert(std::make_pair(x.i, x));
575 if (
this == &other)
return *
this;
592 tmp.functions.insert(std::make_pair(x.first,
copy(x.second)));
598 for (
auto& x :
functions) x.second.function.reconstruct();
626 template<
typename Archive>
628 typedef std::vector<std::pair<std::size_t, CCFunction<double,3>>>
CC_functionvec;
638 if (ar.is_input_archive) {
643 for (
auto& t :
tmp) ar & t.first & t.second;
645 }
else if (ar.is_output_archive) {
648 for (
auto& t :
tmp) ar & t.first & t.second;
653 hashT hashval = std::hash<FuncType>{}(
type);
705 for (
size_t i = 0; i <
v.size(); i++) {
714 for (
auto x:
functions)
tmp.push_back(x.second.function);
725 print_size(
const std::string& msg =
"!?not assigned!?")
const;
730 const size_t freeze =
functions.cbegin()->first;
737 ktmp.second.function.scale(factor);
745 void plot(
const std::string& msg =
"")
const {
747 ktmp.second.plot(msg);
759template<
typename T=
double, std::
size_t NDIM=3>
782 template<
typename archiveT>
811 param.freeze=
a.parameters.freeze;
815 friend std::shared_ptr<CCConvolutionOperator>
combine(
const std::shared_ptr<CCConvolutionOperator>&
a,
816 const std::shared_ptr<CCConvolutionOperator>&
b) {
827 if (
op)
return ((*
op)(
f)).truncate();
836 std::vector<Function<T, NDIM>> result;
837 if constexpr (
NDIM == 3) {
842 result.push_back(
tmpi);
887 std::stringstream
ss;
915 for (
const auto&
tmp:
imH.allpairs)
916 tmp.second.print_size(
"<H" + std::to_string(
tmp.first.first) +
"|" +
name() +
"|H" +
917 std::to_string(
tmp.first.second) +
"> intermediate");
919 for (
const auto&
tmp:
imP.allpairs)
920 tmp.second.print_size(
"<H" + std::to_string(
tmp.first.first) +
"|" +
name() +
"|P" +
921 std::to_string(
tmp.first.second) +
"> intermediate");
923 for (
const auto&
tmp:
imR.allpairs)
924 tmp.second.print_size(
"<H" + std::to_string(
tmp.first.first) +
"|" +
name() +
"|R" +
925 std::to_string(
tmp.first.second) +
"> intermediate");
939 std::shared_ptr<SeparatedConvolution<T,NDIM>>
get_op()
const {
return op;};
950 std::shared_ptr<SeparatedConvolution<T,NDIM>>
op;
957 void error(
const std::string& msg)
const {
959 std::cout <<
"\n\n!!!!ERROR in CCConvolutionOperator " <<
name() <<
": " << msg
960 <<
"!!!!!\n\n" << std::endl;
966template<
typename T, std::
size_t NDIM>
1063 for (
const auto&
f :
v) {
1101 std::cout <<
"Intermediate Potential Manager: " << msg <<
"\n";
1117 std::vector<Function<double,3>>
U1;
1206 std::vector<unsigned char>
v;
1257 template<
typename Archive>
1263 if constexpr (Archive::is_input_archive) {
1285 std::string fname=this->
name();
1298 std::string fname =this->
name();
1328 std::string
name =
"???";
1404 template <
typename T,
size_t NDIM>
1413 if (do_print)
f.print_size(
name);
1414 if (
f.is_compressed()) {
1415 if (
world.
rank()==0
and do_print)
print(
"function is compressed -- reconstructing");
1417 if (do_print)
f.print_size(
name+
" reconstructed");
1443 template<
typename T, std::
size_t NDIM>
1449 if (
vp.empty())
return;
1450 for (
const auto&
p :
vp) {
1457 template<
typename...
Args>
1482 const std::string
policy)
const override {
1484 for (
size_t i = 0; i <
vsize1; i++) {
1486 p.push_back(std::make_pair(
batch,1.0));
1503 std::size_t n = std::get<0>(
argtuple).size();
1528 const std::string
policy)
const override {
1530 for (
size_t i = 0; i <
vsize1; i++) {
1532 p.push_back(std::make_pair(
batch,1.0));
1541 name=
"ConstantPart";
1547 typedef std::tuple<const std::vector<CCPair>&,
1548 const std::vector<Function<double,3>>&,
const std::vector<Function<double,3>>&,
1554 std::size_t n = std::get<0>(
argtuple).size();
1561 const Info& info)
const;
1573 const std::string
policy)
const override {
1575 for (
size_t i = 0; i <
vsize1; i++) {
1577 p.push_back(std::make_pair(
batch, 1.0));
1585 name=
"MP2UpdatePair";
1592 typedef std::tuple<const std::vector<CCPair>&,
const std::vector<real_function_6d>&,
1598 std::size_t n = std::get<0>(
argtuple).size();
1619 const std::string
policy)
const override {
1621 for (
size_t i = 0; i <
vsize1; i++) {
1623 p.push_back(std::make_pair(
batch,1.0));
1635 const std::vector<CCPair>&,
1636 const std::vector<real_function_6d>&,
1646 std::size_t n = std::get<0>(
argtuple).size();
1667 const std::size_t&
maxiter)
const;
1675 name=
"SinglesPotentialEx";
1681 const std::vector<int>&,
1683 const std::vector<CCPair>&,
1685 const std::vector<CCPair>&,
1690 using resultT = std::tuple<std::vector<real_function_3d>,std::vector<real_function_3d>>;
1693 std::size_t n = std::get<0>(
argtuple).size();
1713 name=
"SinglesPotentialGs";
1717 const std::vector<int>&,
1719 const std::vector<CCPair>&,
1725 using resultT = std::tuple<std::vector<real_function_3d>,std::vector<real_function_3d>>;
1729 std::size_t n = std::get<0>(
argtuple).size();
1748 name=
"CorrelationEnergy";
1752 const std::vector<CCPair>&,
1758 typedef std::vector<ScalarResult<double>>
resultT;
1763 std::size_t n = std::get<0>(
argtuple).size();
1769 const Info& info)
const;
double potential(const coord_3d &r)
Definition 3dharmonic.cc:132
Definition macrotaskpartitioner.h:63
a batch consists of a 2D-input batch and a 1D-output batch: K-batch <- (I-batch, J-batch)
Definition macrotaskpartitioner.h:139
Definition CCStructures.h:760
intermediateT< T, NDIM > imH
Definition CCStructures.h:951
CCConvolutionOperator(const CCConvolutionOperator &other)=default
friend hashT hash_value(CCConvolutionOperator< T, NDIM > &op)
Definition CCStructures.h:899
static std::shared_ptr< CCConvolutionOperator > CCConvolutionOperatorPtr(World &world, const OpType type, Parameters param)
Definition CCStructures.h:799
Function< T, NDIM > operator()(const Function< T, NDIM > &f) const
Definition CCStructures.h:826
SeparatedConvolution< T, NDIM > * init_op(const OpType &type, const Parameters ¶meters) const
Definition CCStructures.cc:370
size_t info() const
prints out information (operatorname, number of stored intermediates ...)
Definition CCStructures.cc:352
std::shared_ptr< SeparatedConvolution< T, NDIM > > op
Definition CCStructures.h:950
std::vector< Function< T, NDIM > > operator()(const std::vector< Function< T, NDIM > > &f) const
Definition CCStructures.h:858
OpType type() const
Definition CCStructures.h:935
void clear_intermediates(const FuncType &type)
Definition CCStructures.cc:330
World & world
the world
Definition CCStructures.h:943
void sanity() const
sanity check .. doens not do so much
Definition CCStructures.h:910
std::string name() const
Definition CCStructures.h:886
friend std::shared_ptr< CCConvolutionOperator > combine(const std::shared_ptr< CCConvolutionOperator > &a, const std::shared_ptr< CCConvolutionOperator > &b)
Definition CCStructures.h:815
void update_elements(const CC_vecfunction &bra, const CC_vecfunction &ket)
Definition CCStructures.cc:298
intermediateT< T, NDIM > imP
Definition CCStructures.h:952
void error(const std::string &msg) const
Definition CCStructures.h:957
const Parameters parameters
Definition CCStructures.h:937
CCConvolutionOperator(World &world, const OpType type, Parameters param)
Definition CCStructures.h:792
std::vector< Function< T, NDIM > > operator()(const CC_vecfunction &bra, const CCFunction< T, NDIM > &ket) const
Definition CCStructures.h:834
std::shared_ptr< SeparatedConvolution< T, NDIM > > get_op() const
Definition CCStructures.h:939
void print_intermediate(const FuncType type) const
Definition CCStructures.h:913
intermediateT< T, NDIM > imR
Definition CCStructures.h:953
TwoElectronFactory< T, 2 *NDIM > get_kernel() const
create a TwoElectronFactory with the operatorkernel
Definition CCStructures.h:929
friend CCConvolutionOperator combine(const CCConvolutionOperator &a, const CCConvolutionOperator &b)
Definition CCStructures.h:805
structure for a CC Function 3D which holds an index and a type
Definition ccpairfunction.h:45
Function< T, NDIM > function
Definition ccpairfunction.h:70
size_t i
Definition ccpairfunction.h:78
build an MP2 or CC2 or LRCC2 etc pair, possibly including the lo-rank parts
Definition CCStructures.h:1344
CCPairBuilder & set_ex_singles(const CC_vecfunction &ex)
provide excited state singles, needed for CC2 and LRCC2 wave function ansatz
Definition CCStructures.h:1355
CCPairBuilder(World &world, const Info &info)
Definition CCStructures.h:1346
CC_vecfunction gs_singles
Definition CCStructures.h:1431
const Info & info
Definition CCStructures.h:1430
CCPair make_bare_pair(const int i, const int j) const
make a CCPair without the 6d function and some bookkeeping information
Definition CCStructures.cc:506
CCPairBuilder & set_gs_singles(const CC_vecfunction &gs)
provide ground-state singles, needed for CC2 and LRCC2 wave function ansatz
Definition CCStructures.h:1349
static CCState cc_state(const CalcType &type)
Definition CCStructures.h:1374
CCPair make_bare_pair_from_file(const int i, const int j) const
make a CCPair with the 6d function only and some bookkeeping information
Definition CCStructures.cc:529
World & world
Definition CCStructures.h:1429
Function< T, NDIM > load_function(const std::string name, bool do_print) const
Function to load a function from disk.
Definition CCStructures.h:1405
CCPair make_pair(const int i, const int j, const std::vector< CCPairFunction< double, 6 > > &u) const
make a CCPair
Definition CCStructures.cc:520
CalcType ctype
Definition CCStructures.h:1432
CC_vecfunction ex_singles
Definition CCStructures.h:1431
CCPairBuilder & set_ctype(const CalcType &type)
Definition CCStructures.h:1360
CCPair complete_pair_with_low_rank_parts(const CCPair &pair) const
complete the given pair with the low-rank parts
Definition CCStructures.cc:545
Pairs< CCPair > make_all_bare_pairs() const
make a CCPair with the 6d function only and some bookkeeping information
Definition CCStructures.h:1383
a 6D function, either in full or low rank form, possibly including an 2-particle function
Definition ccpairfunction.h:373
Definition CCStructures.h:1180
void reconstruct() const
reconstruct constant part and all functions
Definition CCStructures.h:1277
hashT hash() const
Definition CCStructures.h:1305
void info() const
Definition CCStructures.cc:84
std::string basename() const
return the base name like "MP2_pair_u" or "CC2_pair_x"
Definition CCStructures.h:1327
CCPair(const CCPair &other)
Definition CCStructures.h:1191
void store_pair(World &world, const bool verbose=false)
Definition CCStructures.h:1297
Recordlist< Cloud::keyT > cloud_store(World &world, Cloud &cloud) const
customized function to store this to the cloud
Definition CCStructures.h:1204
bool function_exists() const
Definition CCStructures.h:1235
std::string name() const
Definition CCStructures.h:1334
CCPair(const size_t ii, const size_t jj, const CCState t, const CalcType c, const std::vector< CCPairFunction< double, 6 > > &f)
Definition CCStructures.h:1187
size_t i
Definition CCStructures.h:1197
bool load_pair(World &world, const bool verbose=false)
Definition CCStructures.h:1284
real_function_6d function() const
gives back the pure 6D part of the pair function
Definition CCStructures.h:1240
real_function_6d constant_part
the constant part
Definition CCStructures.h:1318
std::vector< CCPairFunction< double, 6 > > functions
the functions which belong to the pair
Definition CCStructures.h:1315
CCPair(const size_t ii, const size_t jj, const CCState t, const CalcType c)
Definition CCStructures.h:1184
void update_u(const real_function_6d &u)
updates the pure 6D part of the pair function
Definition CCStructures.h:1247
size_t j
Definition CCStructures.h:1198
CCState type
Definition CCStructures.h:1195
double bsh_eps
Definition CCStructures.h:1324
void serialize(const Archive &ar)
Definition CCStructures.h:1258
CalcType ctype
Definition CCStructures.h:1196
void cloud_load(World &world, const Cloud &cloud, Recordlist< Cloud::keyT > &recordlist)
customized function to load this from the cloud
Definition CCStructures.h:1222
cloud class
Definition cloud.h:147
recordlistT store(madness::World &world, const T &source)
Definition cloud.h:314
T forward_load(madness::World &world, recordlistT &recordlist) const
load a single object from the cloud, recordlist is consumed while loading elements
Definition cloud.h:296
FunctionDefaults holds default paramaters as static class members.
Definition funcdefaults.h:100
static const double & get_thresh()
Returns the default threshold.
Definition funcdefaults.h:176
A multiresolution adaptive numerical function.
Definition mra.h:139
void set_thresh(double value, bool fence=true)
Sets the value of the truncation threshold. Optional global fence.
Definition mra.h:602
const std::shared_ptr< FunctionImpl< T, NDIM > > & get_impl() const
Returns a shared-pointer to the implementation.
Definition mra.h:639
const Function< T, NDIM > & reconstruct(bool fence=true) const
Reconstructs the function, transforming into scaling function basis. Possible non-blocking comm.
Definition mra.h:800
void clear(bool fence=true)
Clears the function as if constructed uninitialized. Optional fence.
Definition mra.h:872
bool is_initialized() const
Returns true if the function is initialized.
Definition mra.h:167
Definition CCStructures.h:1744
resultT operator()(const std::vector< CCPair > &pairs, const CC_vecfunction &singles_gs, const Info &info) const
Definition CCStructures.cc:746
std::tuple< const std::vector< CCPair > &, const CC_vecfunction &, const Info & > argtupleT
Definition CCStructures.h:1755
MacroTaskComputeCorrelationEnergy()
Definition CCStructures.h:1747
resultT allocator(World &world, const argtupleT &argtuple) const
allocate the result and set the name of this task
Definition CCStructures.h:1762
std::vector< ScalarResult< double > > resultT
first vector is the potential, second is an intermediate (if applicable, e.g. for s2b and s2c potenti...
Definition CCStructures.h:1758
std::string basename
Definition CCStructures.h:1746
Definition CCStructures.h:1523
partitionT do_partitioning(const std::size_t &vsize1, const std::size_t &vsize2, const std::string policy) const override
override this if you want your own partitioning
Definition CCStructures.h:1527
ConstantPartPartitioner()
Definition CCStructures.h:1525
Definition CCStructures.h:1521
std::vector< real_function_6d > resultT
Definition CCStructures.h:1551
MacroTaskConstantPart()
Definition CCStructures.h:1539
std::tuple< const std::vector< CCPair > &, const std::vector< Function< double, 3 > > &, const std::vector< Function< double, 3 > > &, const madness::Info & > argtupleT
Definition CCStructures.h:1549
resultT allocator(World &world, const argtupleT &argtuple) const
Definition CCStructures.h:1553
resultT operator()(const std::vector< CCPair > &pair, const std::vector< Function< double, 3 > > &gs_singles, const std::vector< Function< double, 3 > > &ex_singles, const Info &info) const
Definition CCStructures.cc:616
Definition CCStructures.h:1614
IteratePairPartitioner()=default
partitionT do_partitioning(const std::size_t &vsize1, const std::size_t &vsize2, const std::string policy) const override
override this if you want your own partitioning
Definition CCStructures.h:1618
Definition CCStructures.h:1612
std::tuple< const std::vector< CCPair > &, const std::vector< real_function_6d > &, const CC_vecfunction &, const CC_vecfunction &, const Info &, const std::size_t & > argtupleT
Definition CCStructures.h:1641
resultT operator()(const std::vector< CCPair > &pair, const std::vector< real_function_6d > &local_coupling, const CC_vecfunction &gs_singles, const CC_vecfunction &ex_singles, const Info &info, const std::size_t &maxiter) const
iterate a given pair of the MP2, CC2 or LRCC2 calculation
Definition CCStructures.cc:651
MacroTaskIteratePair()
Definition CCStructures.h:1629
resultT allocator(World &world, const argtupleT &argtuple) const
Definition CCStructures.h:1645
std::vector< real_function_6d > resultT
Definition CCStructures.h:1643
Definition CCStructures.h:1477
ConstantPartPartitioner()
Definition CCStructures.h:1479
partitionT do_partitioning(const std::size_t &vsize1, const std::size_t &vsize2, const std::string policy) const override
override this if you want your own partitioning
Definition CCStructures.h:1481
Definition CCStructures.h:1475
resultT operator()(const std::vector< CCPair > &pair, const Info &info, const std::vector< std::string > &argument) const
Definition CCStructures.cc:604
MacroTaskMp2ConstantPart()
Definition CCStructures.h:1493
std::tuple< const std::vector< CCPair > &, const madness::Info &, const std::vector< std::string > & > argtupleT
Definition CCStructures.h:1498
std::vector< real_function_6d > resultT
Definition CCStructures.h:1500
resultT allocator(World &world, const argtupleT &argtuple) const
Definition CCStructures.h:1502
Definition CCStructures.h:1566
UpdatePairPartitioner()
Definition CCStructures.h:1568
partitionT do_partitioning(const std::size_t &vsize1, const std::size_t &vsize2, const std::string policy) const override
override this if you want your own partitioning
Definition CCStructures.h:1572
Definition CCStructures.h:1564
MacroTaskMp2UpdatePair()
Definition CCStructures.h:1583
resultT allocator(World &world, const argtupleT &argtuple) const
Definition CCStructures.h:1597
std::vector< real_function_6d > resultT
Definition CCStructures.h:1595
std::tuple< const std::vector< CCPair > &, const std::vector< real_function_6d > &, const std::vector< madness::Vector< double, 3 > > &, const Info & > argtupleT
Definition CCStructures.h:1593
resultT operator()(const std::vector< CCPair > &pair, const std::vector< real_function_6d > &mp2_coupling, const std::vector< madness::Vector< double, 3 > > &all_coords_vec, const Info &info) const
Definition CCStructures.cc:635
Definition macrotaskq.h:969
Batch batch
Definition macrotaskq.h:971
std::shared_ptr< MacroTaskPartitioner > partitioner
Definition macrotaskq.h:973
std::string name
Definition macrotaskq.h:972
partition one (two) vectors into 1D (2D) batches.
Definition macrotaskpartitioner.h:197
std::string policy
how to partition the batches
Definition macrotaskpartitioner.h:205
std::list< std::pair< Batch, double > > partitionT
Definition macrotaskpartitioner.h:201
MacroTaskPartitioner & set_dimension(const std::size_t &n)
Definition macrotaskpartitioner.h:220
Definition CCStructures.h:1671
std::tuple< std::vector< real_function_3d >, std::vector< real_function_3d > > resultT
Definition CCStructures.h:1690
resultT allocator(World &world, const argtupleT &argtuple) const
Definition CCStructures.h:1692
std::tuple< const std::vector< int > &, const CC_vecfunction &, const std::vector< CCPair > &, const CC_vecfunction &, const std::vector< CCPair > &, const int &, const Info & > argtupleT
Definition CCStructures.h:1688
std::string basename
Definition CCStructures.h:1673
MacroTaskSinglesPotentialEx()
Definition CCStructures.h:1674
resultT operator()(const std::vector< int > &result_index, const CC_vecfunction &singles_gs, const std::vector< CCPair > &doubles_gs, const CC_vecfunction &singles_ex, const std::vector< CCPair > &doubles_ex, const int &name, const Info &info)
convenience function
Definition CCStructures.cc:672
Definition CCStructures.h:1709
std::string basename
Definition CCStructures.h:1711
std::tuple< const std::vector< int > &, const CC_vecfunction &, const std::vector< CCPair > &, const int &, const Info & > argtupleT
Definition CCStructures.h:1722
std::tuple< std::vector< real_function_3d >, std::vector< real_function_3d > > resultT
first vector is the potential, second is an intermediate (if applicable, e.g. for s2b and s2c potenti...
Definition CCStructures.h:1725
resultT operator()(const std::vector< int > &result_index, const CC_vecfunction &singles_gs, const std::vector< CCPair > &doubles_gs, const int &name, const Info &info)
Definition CCStructures.cc:714
MacroTaskSinglesPotentialGs()
Definition CCStructures.h:1712
resultT allocator(World &world, const argtupleT &argtuple) const
allocate the result and set the name of this task
Definition CCStructures.h:1728
class for holding the parameters for calculation
Definition QCCalculationParametersBase.h:290
virtual void read_input_and_commandline_options(World &world, const commandlineparser &parser, const std::string tag)
Definition QCCalculationParametersBase.h:325
Convolutions in separated form (including Gaussian)
Definition operator.h:139
static OperatorInfo combine_OT(const SeparatedConvolution< Q, NDIM > &left, const SeparatedConvolution< Q, NDIM > &right)
return operator type and other info of the combined operator (e.g. fg = f(1,2)* g(1,...
Definition operator.h:1706
A tensor is a multidimensional array.
Definition tensor.h:317
factory for generating TwoElectronInterfaces
Definition function_factory.h:436
A simple, fixed dimension vector.
Definition vector.h:64
void fence(bool debug=false)
Synchronizes all processes in communicator AND globally ensures no pending AM or tasks.
Definition worldgop.cc:161
std::vector< T > concat0(const std::vector< T > &v, size_t bufsz=1024 *1024)
Concatenate an STL vector of serializable stuff onto node 0.
Definition worldgop.h:953
void sum(T *buf, size_t nelem)
Inplace global sum while still processing AM & tasks.
Definition worldgop.h:870
A parallel world class.
Definition world.h:132
ProcessID rank() const
Returns the process rank in this World (same as MPI_Comm_rank()).
Definition world.h:320
WorldGopInterface & gop
Global operations.
Definition world.h:207
static std::enable_if_t< std::is_same< X, BinaryFstreamInputArchive >::value||std::is_same< X, BinaryFstreamOutputArchive >::value, bool > exists(World &world, const char *filename)
Returns true if the named, unopened archive exists on disk with read access.
Definition parallel_archive.h:224
An archive for storing local or parallel data wrapping a BinaryFstreamOutputArchive.
Definition parallel_archive.h:321
Objects that implement their own parallel archive interface should derive from this class.
Definition parallel_archive.h:58
Wraps an archive around an STL vector for output.
Definition vector_archive.h:55
double(* f1)(const coord_3d &)
Definition derivatives.cc:55
char * p(char *buf, const char *name, int k, int initial_level, double thresh, int order)
Definition derivatives.cc:72
static bool debug
Definition dirac-hatom.cc:16
auto T(World &world, response_space &f) -> response_space
Definition global_functions.cc:34
Tensor< typename Tensor< T >::scalar_type > arg(const Tensor< T > &t)
Return a new tensor holding the argument of each element of t (complex types only)
Definition tensor.h:2502
const int maxiter
Definition gygi_soltion.cc:68
static const double v
Definition hatom_sf_dirac.cc:20
static double u(double r, double c)
Definition he.cc:20
Tensor< double > op(const Tensor< double > &x)
Definition kain.cc:508
Declares the macrotaskq and MacroTaskBase classes.
#define MADNESS_CHECK(condition)
Check a condition — even in a release build the condition is always evaluated so it can have side eff...
Definition madness_exception.h:182
#define MADNESS_EXCEPTION(msg, value)
Macro for throwing a MADNESS exception.
Definition madness_exception.h:119
#define MADNESS_CHECK_THROW(condition, msg)
Check a condition — even in a release build the condition is always evaluated so it can have side eff...
Definition madness_exception.h:207
Main include file for MADNESS and defines Function interface.
Namespace for all elements and tools of MADNESS.
Definition DFParameters.h:10
long get_memory_usage()
Definition unique_filename.cc:29
static const char * filename
Definition legendre.cc:96
CalcType
Calculation Types used by CC2.
Definition CCStructures.h:27
@ CT_CC2
Definition CCStructures.h:28
@ CT_LRCC2
Definition CCStructures.h:28
@ CT_MP3
Definition CCStructures.h:28
@ CT_UNDEFINED
Definition CCStructures.h:28
@ CT_LRCCS
Definition CCStructures.h:28
@ CT_CISPD
Definition CCStructures.h:28
@ CT_TEST
Definition CCStructures.h:28
@ CT_MP2
Definition CCStructures.h:28
@ CT_ADC2
Definition CCStructures.h:28
@ CT_TDHF
Definition CCStructures.h:28
static std::string stringify(T arg)
Definition funcplot.h:1034
static double cpu_time()
Returns the cpu time in seconds relative to an arbitrary origin.
Definition timers.h:127
void print_memory_usage(const World &world)
check memory usage using getrusage
Definition CCStructures.h:77
Function< TENSOR_RESULT_TYPE(Q, T), NDIM > mul(const Q alpha, const Function< T, NDIM > &f, bool fence=true)
Returns new function equal to alpha*f(x) with optional fence.
Definition mra.h:1733
void truncate(World &world, response_space &v, double tol, bool fence)
Definition basic_operators.cc:30
CCState
Type of Pairs used by CC_Pair2 class.
Definition CCStructures.h:31
@ CCSTATE_UNDEFINED
Definition CCStructures.h:32
@ GROUND_STATE
Definition CCStructures.h:32
@ EXCITED_STATE
Definition CCStructures.h:32
FuncType
Definition ccpairfunction.h:26
@ RESPONSE
Definition ccpairfunction.h:26
@ HOLE
Definition ccpairfunction.h:26
@ UNDEFINED
Definition ccpairfunction.h:26
@ PARTICLE
Definition ccpairfunction.h:26
@ reconstructed
s coeffs at the leaves only
Definition funcdefaults.h:60
CalcType assign_calctype(const std::string name)
Assigns enum to string.
Definition CCStructures.cc:396
const std::vector< Function< T, NDIM > > & reconstruct(const std::vector< Function< T, NDIM > > &v)
reconstruct a vector of functions
Definition vmra.h:156
std::shared_ptr< CCConvolutionOperator< T, NDIM > > CCConvolutionOperatorPtr(World &world, const OpType type, typename CCConvolutionOperator< T, NDIM >::Parameters param)
Definition CCStructures.h:967
void hash_combine(hashT &seed, const T &v)
Combine hash values.
Definition worldhash.h:260
double size_of(const intermediateT< T, NDIM > &im)
Returns the size of an intermediate.
Definition CCStructures.h:511
std::vector< real_function_3d > vector_real_function_3d
Definition functypedefs.h:94
std::shared_ptr< FunctionFunctorInterface< double, 3 > > func(new opT(g))
OpType
operator types
Definition operatorinfo.h:11
void print(const T &t, const Ts &... ts)
Print items to std::cout (items separated by spaces) and terminate with a new line.
Definition print.h:225
response_space apply(World &world, std::vector< std::vector< std::shared_ptr< real_convolution_3d > > > &op, response_space &f)
Definition basic_operators.cc:39
std::string get_hostname()
Definition unique_filename.cc:40
NDIM & f
Definition mra.h:2448
std::size_t hashT
The hash value type.
Definition worldhash.h:145
double wall_time()
Returns the wall time in seconds relative to an arbitrary origin.
Definition timers.cc:48
std::string type(const PairType &n)
Definition PNOParameters.h:18
constexpr Vector< T, sizeof...(Ts)+1 > vec(T t, Ts... ts)
Factory function for creating a madness::Vector.
Definition vector.h:750
PotentialType
CC2 Singles Potentials.
Definition CCStructures.h:36
@ POT_singles_
Definition CCStructures.h:53
@ POT_s2b_
Definition CCStructures.h:45
@ POT_F3D_
Definition CCStructures.h:38
@ POT_s5b_
Definition CCStructures.h:43
@ POT_s4c_
Definition CCStructures.h:49
@ POT_s5c_
Definition CCStructures.h:44
@ POT_s6_
Definition CCStructures.h:50
@ POT_s4b_
Definition CCStructures.h:48
@ POT_ccs_
Definition CCStructures.h:51
@ POT_s3c_
Definition CCStructures.h:41
@ POT_s4a_
Definition CCStructures.h:47
@ POT_s5a_
Definition CCStructures.h:42
@ POT_s3b_
Definition CCStructures.h:40
@ POT_s2c_
Definition CCStructures.h:46
@ POT_cis_
Definition CCStructures.h:52
@ POT_UNDEFINED
Definition CCStructures.h:37
@ POT_s3a_
Definition CCStructures.h:39
std::string assign_name(const CCState &input)
Assigns strings to enums for formated output.
Definition CCStructures.cc:379
static XNonlinearSolver< std::vector< Function< T, NDIM > >, T, vector_function_allocator< T, NDIM > > nonlinear_vector_solver(World &world, const long nvec)
Definition nonlinsol.h:284
std::string name(const FuncType &type, const int ex=-1)
Definition ccpairfunction.h:28
madness::hashT hash_value(const std::array< T, N > &a)
Hash std::array with madness hash.
Definition array_addons.h:78
void save(const Function< T, NDIM > &f, const std::string name)
Definition mra.h:2777
double get_size(World &world, const std::vector< Function< T, NDIM > > &v)
Definition vmra.h:1721
double get_size_local(World &world, const std::vector< Function< T, NDIM > > &v)
return the size of a vector of functions for each rank
Definition vmra.h:1702
static const double b
Definition nonlinschro.cc:119
static const double a
Definition nonlinschro.cc:118
static const double c
Definition relops.cc:10
static const double thresh
Definition rk.cc:45
parameter class
Definition CCStructures.h:764
int freeze
Definition CCStructures.h:779
Parameters()
Definition CCStructures.h:765
void serialize(archiveT &ar)
f12 exponent
Definition CCStructures.h:783
double lo
Definition CCStructures.h:778
double gamma
Definition CCStructures.h:780
Parameters(const CCParameters ¶m)
Definition CCStructures.h:774
double thresh_op
Definition CCStructures.h:777
Parameters(const Parameters &other)
Definition CCStructures.h:767
Definition CCStructures.h:90
void print_warnings() const
Definition CCStructures.h:116
void warning(const std::string &msg) const
Definition CCStructures.cc:45
void debug_output(const std::string &msg) const
Definition CCStructures.h:100
bool debug
Definition CCStructures.h:96
void subsection(const std::string &msg) const
Definition CCStructures.cc:34
CCMessenger operator<<(const T &t) const
Definition CCStructures.h:121
World & world
Definition CCStructures.h:93
bool scientific
Definition CCStructures.h:95
std::vector< std::string > warnings
collect all warnings that occur to print out at the end of the job
Definition CCStructures.h:128
std::ostream & os
output stream
Definition CCStructures.h:130
void section(const std::string &msg) const
Definition CCStructures.cc:23
void output(const std::string &msg) const
Definition CCStructures.cc:14
CCMessenger(World &world)
Definition CCStructures.h:91
size_t output_prec
Definition CCStructures.h:94
void operator()(const std::string &msg) const
Definition CCStructures.h:98
Definition CCStructures.h:213
double thresh_Ue() const
Definition CCStructures.h:317
double thresh_f12() const
Definition CCStructures.h:315
std::size_t kain_subspace() const
Definition CCStructures.h:367
double tight_thresh_6D() const
Definition CCStructures.h:307
std::size_t iter_max_3D() const
Definition CCStructures.h:329
bool no_compute_cispd() const
Definition CCStructures.h:349
CCParameters(World &world, const commandlineparser &parser)
ctor reading out the input file
Definition CCStructures.h:223
bool no_compute_mp2_constantpart() const
Definition CCStructures.h:341
std::pair< int, int > only_pair() const
Definition CCStructures.h:333
bool kain() const
Definition CCStructures.h:357
bool plot() const
Definition CCStructures.h:355
bool no_compute_response() const
Definition CCStructures.h:343
double thresh_poisson() const
Definition CCStructures.h:313
CCParameters()
Definition CCStructures.h:215
double thresh_bsh_3D() const
Definition CCStructures.h:309
bool no_compute_mp2() const
Definition CCStructures.h:345
double dconv_6D() const
Definition CCStructures.h:325
double econv_pairs() const
Definition CCStructures.h:321
void initialize_parameters()
Definition CCStructures.h:230
bool response() const
Definition CCStructures.h:296
bool decompose_Q() const
Definition CCStructures.h:361
double thresh_bsh_6D() const
Definition CCStructures.h:311
void error(World &world, const std::string &msg) const
Definition CCStructures.h:381
CCParameters(const CCParameters &other)=default
copy constructor
double gamma() const
Definition CCStructures.h:373
double thresh_3D() const
Definition CCStructures.h:301
double tight_thresh_3D() const
Definition CCStructures.h:303
bool no_compute() const
Definition CCStructures.h:337
double dconv_3D() const
Definition CCStructures.h:323
std::size_t iter_max() const
Definition CCStructures.h:327
double lo() const
Definition CCStructures.h:297
long freeze() const
Definition CCStructures.h:369
double thresh_6D() const
Definition CCStructures.h:305
bool no_compute_cc2() const
Definition CCStructures.h:347
std::vector< std::size_t > excitations() const
Definition CCStructures.h:371
void set_derived_values()
Definition CCStructures.cc:159
bool QtAnsatz() const
Definition CCStructures.h:363
bool test() const
Definition CCStructures.h:359
double dmin() const
Definition CCStructures.h:299
std::size_t output_prec() const
Definition CCStructures.h:365
bool restart() const
Definition CCStructures.h:335
double econv() const
Definition CCStructures.h:319
std::size_t iter_max_6D() const
Definition CCStructures.h:331
CalcType calc_type() const
Definition CCStructures.h:283
bool no_compute_gs() const
Definition CCStructures.h:339
bool debug() const
Definition CCStructures.h:353
void information(World &world) const
print out the parameters
Definition CCStructures.cc:191
bool no_compute_lrcc2() const
Definition CCStructures.h:351
size_t warning(World &world, const std::string &msg) const
Definition CCStructures.h:388
void sanity_check(World &world) const
check if parameters are set correct
Definition CCStructures.cc:202
print accumulated size of all functions
Definition CCStructures.h:1438
void print(World &world, const std::string msg="") const
Definition CCStructures.h:1462
double size_local
Definition CCStructures.h:1439
void add_helper(const std::vector< CCPair > &vp)
Definition CCStructures.h:1448
void add(const Args &... args)
variadic template parameters to add the size of all functions and pairs
Definition CCStructures.h:1458
void add_helper(const std::vector< Function< T, NDIM > > &v)
Definition CCStructures.h:1444
Timer Structure.
Definition CCStructures.h:135
std::pair< double, double > current_time(bool printout=false)
Definition CCStructures.h:188
CCTimer(World &world, std::string msg)
Definition CCStructures.h:139
void print() const
Definition CCStructures.h:197
std::string operation
Definition CCStructures.h:146
double start_cpu
Definition CCStructures.h:145
double time_wall
Definition CCStructures.h:149
double get_wall_time_diff() const
Definition CCStructures.h:184
void update_time()
Definition CCStructures.h:152
CCTimer stop()
Definition CCStructures.h:168
CCTimer start()
Definition CCStructures.h:162
void print()
Definition CCStructures.h:193
double time_cpu
Definition CCStructures.h:150
double start_wall
Definition CCStructures.h:144
double get_cpu_time_diff() const
Definition CCStructures.h:186
void print(const std::pair< double, double > ×) const
Definition CCStructures.h:201
double reset()
Definition CCStructures.h:176
World & world
Definition CCStructures.h:143
double end_wall
Definition CCStructures.h:147
double end_cpu
Definition CCStructures.h:148
A helper structure which holds a map of functions.
Definition CCStructures.h:523
std::string irrep
Definition CCStructures.h:666
hashT hash() const
Definition CCStructures.h:652
CC_vecfunction(const vector_real_function_3d &v, const FuncType &type, const size_t &freeze)
Definition CCStructures.h:550
std::map< std::size_t, CCFunction< double, 3 > > CC_functionmap
Definition CCStructures.h:659
CC_vecfunction(const CC_vecfunction &other)
copy ctor (shallow)
Definition CCStructures.h:566
const CCFunction< double, 3 > & operator()(const CCFunction< double, 3 > &i) const
getter
Definition CCStructures.h:678
void insert(const size_t &i, const CCFunction< double, 3 > &f)
setter
Definition CCStructures.h:698
CC_vecfunction(const vector_real_function_3d &v, const FuncType &type)
Definition CCStructures.h:542
static CC_vecfunction load_restartdata(World &world, std::string filename)
Definition CCStructures.h:614
const CCFunction< double, 3 > & operator()(const size_t &i) const
getter
Definition CCStructures.h:683
CC_vecfunction operator*(const double &fac) const
scalar multiplication
Definition CCStructures.h:728
double delta
Definition CCStructures.h:665
CCFunction< double, 3 > & operator()(const size_t &i)
getter
Definition CCStructures.h:693
void print_size(const std::string &msg="!?not assigned!?") const
Print the memory of which is used by all the functions in the map.
Definition CCStructures.cc:69
CC_vecfunction(const std::vector< CCFunction< double, 3 > > &v)
Definition CCStructures.h:536
bool operator<(const CC_vecfunction &b) const
operator needed for sort operation (sorted by omega values)
Definition CCStructures.h:742
CC_vecfunction(const FuncType type_)
Definition CCStructures.h:527
void serialize(const Archive &ar)
Definition CCStructures.h:627
CC_vecfunction(const std::vector< CCFunction< double, 3 > > &v, const FuncType type_)
Definition CCStructures.h:560
CC_vecfunction(const vector_real_function_3d &v)
Definition CCStructures.h:529
CC_vecfunction()
Definition CCStructures.h:525
void set_functions(const vector_real_function_3d &v, const FuncType &type, const size_t &freeze)
setter
Definition CCStructures.h:703
CCFunction< double, 3 > & operator()(const CCFunction< double, 3 > &i)
getter
Definition CCStructures.h:688
void scale(const double &factor)
scaling (inplace)
Definition CCStructures.h:735
void plot(const std::string &msg="") const
Definition CCStructures.h:745
FuncType type
Definition CCStructures.h:662
double current_error
excitation energy
Definition CCStructures.h:664
friend CC_vecfunction copy(const CC_vecfunction &other)
returns a deep copy (void shallow copy errors)
Definition CCStructures.h:588
size_t size() const
Get the size vector (number of functions in the map)
Definition CCStructures.h:719
CC_vecfunction & operator=(const CC_vecfunction &other)
assignment operator, shallow wrt the functions
Definition CCStructures.h:574
double omega
Definition CCStructures.h:663
bool is_converged(const double econv, const double dconv) const
Definition CCStructures.h:673
vector_real_function_3d get_vecfunction() const
Returns all the functions of the map as vector.
Definition CCStructures.h:712
void save_restartdata(World &world, std::string filename) const
Definition CCStructures.h:621
CC_functionmap functions
Definition CCStructures.h:660
std::string name(const int ex) const
excitation irrep (direct product of x function and corresponding orbital)
Definition CCStructures.h:669
void reconstruct() const
Definition CCStructures.h:597
POD holding some basic functions and some intermediates for the CC2 calculation.
Definition CCStructures.h:1108
void reconstruct() const
Definition CCStructures.h:1131
std::vector< Function< double, 3 > > mo_ket
Definition CCStructures.h:1109
Recordlist< Cloud::keyT > cloud_store(World &world, Cloud &cloud) const
customized function to store this to the cloud
Definition CCStructures.h:1144
Tensor< double > fock
Definition CCStructures.h:1114
Function< double, 3 > R
Definition CCStructures.h:1116
std::vector< Function< double, 3 > > U1
Definition CCStructures.h:1117
CCIntermediatePotentials intermediate_potentials
Definition CCStructures.h:1115
Function< double, 3 > U2
Definition CCStructures.h:1116
std::vector< madness::Vector< double, 3 > > molecular_coordinates
Definition CCStructures.h:1111
std::vector< double > orbital_energies
Definition CCStructures.h:1113
std::vector< Function< double, 3 > > mo_bra
Definition CCStructures.h:1110
CCParameters parameters
Definition CCStructures.h:1112
vector_real_function_3d get_active_mo_bra() const
Definition CCStructures.h:1125
void cloud_load(World &world, const Cloud &cloud, Recordlist< Cloud::keyT > &recordlist)
customized function to load this from the cloud
Definition CCStructures.h:1163
Function< double, 3 > R_square
Definition CCStructures.h:1116
vector_real_function_3d get_active_mo_ket() const
Definition CCStructures.h:1119
Definition CCStructures.h:395
static PairVectorMap triangular_map(const int nfreeze, const int nocc)
Definition CCStructures.h:401
void print(const std::string msg="PairVectorMap") const
Definition CCStructures.h:421
std::vector< std::pair< int, int > > map
maps pair index (i,j) to vector index k
Definition CCStructures.h:397
static PairVectorMap quadratic_map(const int nfreeze, const int nocc)
Definition CCStructures.h:411
PairVectorMap(const std::vector< std::pair< int, int > > map1)
Definition CCStructures.h:399
Definition CCStructures.h:435
void swap(Pairs< T > &other)
swap the contant of the pairmap
Definition CCStructures.h:491
pairmapT allpairs
Definition CCStructures.h:438
static Pairs vector2pairs(const std::vector< T > &argument, const PairVectorMap map)
Definition CCStructures.h:454
Pairs< R > convert(const Pairs< T > arg, const opT op) const
convert Pairs<T> to another type
Definition CCStructures.h:444
std::map< std::pair< int, int >, T > pairmapT
Definition CCStructures.h:437
bool empty() const
Definition CCStructures.h:495
T & operator()(int i, int j)
getter
Definition CCStructures.h:478
void insert(int i, int j, const T &pair)
Definition CCStructures.h:485
const T & operator()(int i, int j) const
getter
Definition CCStructures.h:471
static std::vector< T > pairs2vector(const Pairs< T > &argument, const PairVectorMap map)
Definition CCStructures.h:462
very simple command line parser
Definition commandlineparser.h:15
Definition lowrankfunction.h:332
static double current_time
Definition tdse1d.cc:160
InputParameters param
Definition tdse.cc:203
double norm(const T i1)
Definition test_cloud.cc:72
constexpr std::size_t NDIM
Definition testgconv.cc:54
double h(const coord_1d &r)
Definition testgconv.cc:175