32#ifndef MADNESS_MRA_FUNCIMPL_H__INCLUDED
33#define MADNESS_MRA_FUNCIMPL_H__INCLUDED
58 template <
typename T, std::
size_t NDIM>
61 template<
typename T, std::
size_t NDIM>
64 template<
typename T, std::
size_t NDIM>
67 template<
typename T, std::
size_t NDIM>
70 template<
typename T, std::
size_t NDIM>
71 class FunctionFactory;
73 template<
typename T, std::
size_t NDIM, std::
size_t MDIM>
74 class CompositeFunctorInterface;
85 template<
typename keyT>
104 template <
typename keyT>
115 Level n = key.level();
116 if (n == 0)
return 0;
118 if (n <= 3 || (n&0x1)) hash = key.
hash();
126 template<
typename T, std::
size_t NDIM>
177 if (
this != &other) {
288 print(
"set_coeff: may have a problem");
289 print(
"set_coeff: coeff.dim[0] =", coeffs.
dim(0),
", 2* MAXK =", 2*
MAXK);
300 template <
typename Q>
339 }
else if (
coeff().dim(0) == cdata.
vk[0]) {
342 }
else if (
coeff().is_full_tensor()) {
348 }
else if (
coeff().is_svd_tensor()) {
364 template <
typename Q,
typename R>
405 if (
c.is_local(parent))
436 if (
c.is_local(parent))
454 return this->_coeffs.trace_conj((rhs.
_coeffs));
457 template <
typename Archive>
467 s <<
"\"has_coeff\":" << this->
has_coeff()
468 <<
",\"has_children\":" << this->
has_children() <<
",\"norm\":";
475 s <<
norm <<
",\"norm_tree\":" << nt <<
",\"snorm\":"
478 if (this->
coeff().is_assigned())
479 s <<
",\"dim\":" << this->
coeff().
dim(0);
484 template <
typename T, std::
size_t NDIM>
491 if (nt == 1e300) nt = 0.0;
499 template<
typename T,
size_t NDIM>
526 if (key.
level()<2)
return false;
528 std::vector<Slice>
s0(
NDIM/2,s);
530 const double tol=
f->get_thresh();
531 const double thresh=
f->truncate_tol(tol, key)*0.3;
533 const double fnorm=fcoeff.
normf();
534 const double gnorm=gcoeff.
normf();
537 const double norm=fnorm*gnorm;
541 const double sfnorm=fcoeff(
s0).
normf();
542 const double sgnorm=gcoeff(
s0).
normf();
546 const double ferror=sqrt(
std::abs(fnorm*fnorm-sfnorm*sfnorm));
547 const double gerror=sqrt(
std::abs(gnorm*gnorm-sgnorm*sgnorm));
550 const double error=fnorm*gerror + ferror*gnorm + ferror*gerror;
556 template <
typename Archive>
void serialize (Archive& ar) {
563 template<
typename T,
size_t NDIM,
typename opT>
579 if (key.
level()<2)
return false;
580 const double cnorm=coeff.
normf();
586 if (key.
level()<2)
return false;
589 const opkeyT
source=
op->get_source_key(key);
592 const std::vector<opkeyT>& disp =
op->get_disp(key.
level());
593 const opkeyT&
d = *disp.begin();
595 const double norm=opnorm*cnorm;
600 template <
typename Archive>
void serialize (Archive& ar) {
609 template<
typename T,
size_t NDIM,
size_t LDIM,
typename opT>
641 if (key.
level()<2)
return false;
643 const double tol=
f->get_thresh();
644 const double thresh=
f->truncate_tol(tol, key);
646 const double fnorm=fcoeff.
normf();
647 const double gnorm=gcoeff.
normf();
650 const double sfnorm=fcoeff(
g->get_cdata().s0).
normf();
651 const double sgnorm=gcoeff(
g->get_cdata().s0).
normf();
654 const double norm=fnorm*gnorm;
658 const double ferror=sqrt(fnorm*fnorm-sfnorm*sfnorm);
659 const double gerror=sqrt(gnorm*gnorm-sgnorm*sgnorm);
662 const double error=fnorm*gerror + ferror*gnorm + ferror*gerror;
666 const std::vector<Key<NDIM> >& disp =
op->get_disp(key.
level());
668 const double opnorm =
op->norm(key.
level(),
d, key);
669 const double final_norm=opnorm*sfnorm*sgnorm;
670 if (final_norm <
thresh)
return true;
674 template <
typename Archive>
void serialize (Archive& ar) {
679 template<
typename T,
size_t NDIM>
686 template <
typename Archive>
void serialize (Archive& ar) {}
691 template<
typename T, std::
size_t NDIM>
706 template <
typename Archive>
void serialize (Archive& ar) {
715 template<
typename T, std::
size_t NDIM>
726 impl->get_coeffs().task(key, &nodeT::accumulate, coeff,
impl->get_coeffs(), key,
impl->get_tensor_args());
728 template <
typename Archive>
void serialize (Archive& ar) {
741 template<
typename T,
typename R>
743 template <
typename Archive>
void serialize (Archive& ar) {}
748 template<
typename T, std::
size_t NDIM>
757 dnorm(node.get_dnorm()) {}
766 template <
typename Archive>
790 template<
typename T,
size_t NDIM>
915 template <
typename Archive>
void serialize(
const Archive& ar) {
922 template<
typename T, std::
size_t NDIM>
944 template <
typename T, std::
size_t NDIM>
951 typedef std::shared_ptr< FunctionImpl<T,NDIM> >
pimplT;
958 typedef std::pair<const keyT,nodeT>
datumT;
986 std::shared_ptr< FunctionFunctorInterface<T,NDIM> >
functor;
1007 ,
world(factory._world)
1009 ,
thresh(factory._thresh)
1032 bool do_refine = factory.
_refine;
1042 std::vector<coordT> functor_special_points=
functor->special_points();
1043 if (!functor_special_points.empty())
special_points.insert(
special_points.end(), functor_special_points.begin(), functor_special_points.end());
1049 if (it->second.is_leaf())
1070 template <
typename Q>
1084 template <
typename Q>
1118 const std::shared_ptr< WorldDCPmapInterface< Key<NDIM> > >&
get_pmap()
const;
1130 std::list<keyT> keys;
1138 currentmap->redistribute(
world,newmap);
1144 template <
typename Q>
1154 template<
typename Q>
1162 copy_remote_coeffs_from_pid<Q>(pid, other);
1168 copy_remote_coeffs_from_pid<Q>(other.
get_pmap()->owner(
key0), other);
1174 template <
typename Q>
1178 auto v=other.
task(pid, &implQ::serialize_remote_coeffs);
1184 std::vector<unsigned char>
v;
1197 template <
typename Q>
1199 for (
const auto& [key, node] : other.
coeffs) {
1211 template<
typename Q,
typename R>
1231 template<
typename Q,
typename R>
1243 template<
typename Q,
typename R>
1260 const double beta,
const implT&
g,
const bool fence);
1263 template <
typename Q,
typename R>
1272 const keyT& key = it->first;
1275 f->coeffs.send(key, &nodeT:: template gaxpy_inplace<Q,R>,
alpha, other_node,
beta);
1278 template <
typename Archive>
1291 template <
typename Q,
typename R>
1304 template <
typename Archive>
1322 template <
typename Archive>
1362 std::shared_ptr<FunctionFunctorInterface<T,NDIM> >
get_functor();
1364 std::shared_ptr<FunctionFunctorInterface<T,NDIM> >
get_functor()
const;
1416 void truncate(
double tol,
bool fence);
1453 void print_tree(std::ostream& os = std::cout,
Level maxlevel = 10000)
const;
1486 double val2=log10(val) - log10(
lower());
1488 val2=0.7-(0.7/
upper)*val2;
1489 color= std::max(0.0,val2);
1490 color= std::min(0.7,color);
1492 double hue=0.7-(0.7/
limit)*(val);
1493 color= std::max(0.0,hue);
1520 const int xaxis,
const int yaxis,
const coordT el2);
1542 template<
size_t FDIM>
1543 typename std::enable_if<NDIM==FDIM>::type
1544 read_grid(
const std::string keyfile,
const std::string gridfile,
1547 std::ifstream kfile(keyfile.c_str());
1548 std::ifstream gfile(gridfile.c_str());
1552 if (not (std::getline(kfile,line)))
MADNESS_EXCEPTION(
"failed reading 1st line of key data",0);
1553 if (not (std::istringstream(line) >> ndata))
MADNESS_EXCEPTION(
"failed reading k",0);
1554 if (not (std::getline(gfile,line)))
MADNESS_EXCEPTION(
"failed reading 1st line of grid data",0);
1555 if (not (std::istringstream(line) >> ndata1))
MADNESS_EXCEPTION(
"failed reading k",0);
1557 if (not (std::getline(kfile,line)))
MADNESS_EXCEPTION(
"failed reading 2nd line of key data",0);
1558 if (not (std::getline(gfile,line)))
MADNESS_EXCEPTION(
"failed reading 2nd line of grid data",0);
1562 const size_t npt = qx.
dim(0);
1565 long npoints=power<NDIM>(npt);
1567 long nboxes=ndata/npoints;
1569 print(
"reading ",nboxes,
"boxes from file",gridfile,keyfile);
1575 std::string gline,kline;
1577 while (std::getline(kfile,kline)) {
1579 double x,y,z,x1,y1,z1,val;
1586 std::stringstream(kline) >> nn >> l1 >> l2 >> l3;
1594 const double h = std::pow(0.5,
double(n));
1601 for (
size_t i=0; i<npt; ++i) {
1602 c[0] =
cell(0,0) +
h*cell_width[0]*(l[0] + qx(i));
1603 for (
size_t j=0; j<npt; ++j) {
1604 c[1] =
cell(1,0) +
h*cell_width[1]*(l[1] + qx(j));
1605 for (
size_t k=0;
k<npt; ++
k) {
1606 c[2] =
cell(2,0) +
h*cell_width[2]*(l[2] + qx(
k));
1608 auto& success1 = std::getline(gfile,gline);
MADNESS_CHECK(success1);
1609 auto& success2 = std::getline(kfile,kline);
MADNESS_CHECK(success2);
1610 std::istringstream(gline) >> x >> y >> z >> val;
1611 std::istringstream(kline) >> x1 >> y1 >> z1;
1620 if (vnuc_functor) val-=(*vnuc_functor)(
c);
1630 const bool has_children=
false;
1632 nodeT node(coeff,has_children);
1649 template<
size_t FDIM>
1650 typename std::enable_if<NDIM==FDIM>::type
1654 std::ifstream gfile(gridfile.c_str());
1658 if (not (std::getline(gfile,line)))
MADNESS_EXCEPTION(
"failed reading 1st line of grid data",0);
1659 if (not (std::istringstream(line) >> ndata))
MADNESS_EXCEPTION(
"failed reading k",0);
1660 if (not (std::getline(gfile,line)))
MADNESS_EXCEPTION(
"failed reading 2nd line of grid data",0);
1664 const size_t npt = qx.
dim(0);
1667 long npoints=power<NDIM>(npt);
1669 long nboxes=ndata/npoints;
1671 print(
"reading ",nboxes,
"boxes from file",gridfile);
1679 while (std::getline(gfile,gline)) {
1681 double x1,y1,z1,val;
1688 std::stringstream(gline) >> nn >> l1 >> l2 >> l3;
1695 const double h = std::pow(0.5,
double(n));
1702 for (
int i=0; i<npt; ++i) {
1703 c[0] =
cell(0,0) +
h*cell_width[0]*(l[0] + qx(i));
1704 for (
int j=0; j<npt; ++j) {
1705 c[1] =
cell(1,0) +
h*cell_width[1]*(l[1] + qx(j));
1706 for (
int k=0;
k<npt; ++
k) {
1707 c[2] =
cell(2,0) +
h*cell_width[2]*(l[2] + qx(
k));
1709 auto& success = std::getline(gfile,gline);
1711 std::istringstream(gline) >> x1 >> y1 >> z1 >> val;
1717 if (vnuc_functor) val-=(*vnuc_functor)(
c);
1727 const bool has_children=
false;
1729 nodeT node(coeff,has_children);
1805 const coeffT& coeff)
const;
1811 template <
typename Q>
1827 template <
typename Q>
1829 const bool s_only)
const {
1863 template <
typename Q>
1881 for (std::size_t
d=0;
d<
NDIM; ++
d) {
1912 template <
typename Q>
1937 template <
typename Q>
1944 template <
typename Q>
1951 template <
typename Q>
1965 template <
typename Q>
1972 MADNESS_EXCEPTION(
"FunctionImpl: fcube_for_mul: child-parent relationship bad?",0);
1976 for (std::size_t
d=0;
d<
NDIM; ++
d) {
1993 template <
typename Q>
2000 MADNESS_EXCEPTION(
"FunctionImpl: fcube_for_mul: child-parent relationship bad?",0);
2004 for (
size_t d=0;
d<
NDIM;
d++) {
2015 template <
typename L,
typename R>
2040 template<
typename R>
2042 const int npt,
const keyT& key)
const {
2049 c11(this->cdata.
s0)=c1;
2050 c22(this->cdata.
s0)=c2;
2062 return copy(result(this->cdata.
s0));
2067 template <
typename L,
typename R,
typename opT>
2078 op(key, tcube, lcube, rcube);
2090 template <
typename L,
typename R>
2100 const keyT& key = it->first;
2102 coeffs.
send(key, &nodeT:: template gaxpy_inplace<T,L>, 1.0, other_node,
alpha);
2108 const keyT& key = it->first;
2110 coeffs.
send(key, &nodeT:: template gaxpy_inplace<T,R>, 1.0, other_node,
beta);
2118 template <
typename opT>
2122 const keyT& parent = it->first;
2123 nodeT& node = it->second;
2139 template <
typename opT>
2143 const keyT& parent = it->first;
2144 nodeT& node = it->second;
2156 template<std::
size_t LDIM>
2171 coeffT g_values =
g->coeffs2values(key,g_coeff);
2174 const long rank=g_values.
rank();
2175 const long maxk=
f->get_k();
2181 tensorT result(maxk,maxk,maxk);
2183 for (
long i=0; i<rank; ++i) {
2187 double singular_value_i = g_values.
get_svdtensor().weights(i);
2188 result += (singular_value_i*c1);
2192 tensorT f_coeff =
f->values2coeffs(key1,result);
2201 template<std::
size_t LDIM>
2206 const keyT& key = it->first;
2214 woT::task(
p, &implT:: template dirac_convolution_op<LDIM>, key, node,
f);
2220 f->trickle_down(
true);
2230 template <
typename opT>
2240 template <
typename opT>
2265 const keyT& key = it->first;
2266 nodeT& node = it->second;
2271 const double error=
d.normf();
2277 template <
typename Archive>
void serialize(
const Archive& ar) {}
2290 nodeT& node = it->second;
2294 template <
typename Archive>
void serialize(
const Archive& ar) {}
2306 nodeT& node = it->second;
2310 template <
typename Archive>
void serialize(
const Archive& ar) {}
2325 nodeT& node = it->second;
2330 template <
typename Archive>
void serialize(
const Archive& ar) {}
2352 nodeT& node = it->second;
2356 template <
typename Archive>
void serialize(
const Archive& ar) {}
2372 if constexpr(
NDIM==6) {
2373 const keyT& key = it->first;
2374 const nodeT& fnode = it->second;
2382 std::vector<long> map(
NDIM);
2383 map[0]=3; map[1]=4; map[2]=5;
2384 map[3]=0; map[4]=1; map[5]=2;
2404 if (have_c1 and have_c2) {
2408 norm=(c1-c2).normf();
2409 }
else if (have_c1) {
2412 }
else if (have_c2) {
2432 template <
typename Archive>
void serialize(
const Archive& ar) {
2444 template<
typename Q,
typename R>
2456 const keyT& key = it->first;
2457 const nodeT& node = it->second;
2463 template <
typename Archive>
void serialize(
const Archive& ar) {
2473 template<
typename Q,
typename R>
2486 const keyT& key = it->first;
2487 const nodeT& fnode = it->second;
2493 nodeT& gnode=acc->second;
2503 template <
typename Archive>
void serialize(
const Archive& ar) {
2521 const keyT& key = it->first;
2522 const nodeT& node = it->second;
2533 template <
typename Archive>
void serialize(
const Archive& ar) {
2551 const keyT& key = it->first;
2552 const nodeT& node = it->second;
2557 for (std::size_t i=0; i<
NDIM; ++i) {
2564 std::vector<Slice> s(
___);
2567 for (
size_t i=0; i<
NDIM; ++i) {
2568 std::size_t
kmax=
c.dim(i);
2570 for (
size_t k=1;
k<
kmax;
k+=2) {
2583 template <
typename Archive>
void serialize(
const Archive& ar) {
2602 const keyT& key = it->first;
2603 const nodeT& node = it->second;
2611 for (std::size_t i=0; i<
NDIM; ++i) l1[
map[i]] = l[i];
2620 for (std::size_t i=0; i<
NDIM; ++i) {
2621 if (
mirror[i]==-1) l1[i]= lmax - l[i];
2627 std::vector<Slice> s(
___);
2630 for (
size_t i=0; i<
NDIM; ++i) {
2631 std::size_t
kmax=
c.dim(i);
2633 for (
size_t k=1;
k<
kmax;
k+=2) {
2647 template <
typename Archive>
void serialize(
const Archive& ar) {
2667 const keyT& key = it->first;
2668 const nodeT& fnode = it->second;
2676 nodeT& gnode=acc->second;
2685 template <
typename Archive>
void serialize(
const Archive& ar) {}
2705 nodeT& node = it->second;
2713 template <
typename Archive>
void serialize(
const Archive& ar) {}
2726 it->second.consolidate_buffer(
targs);
2729 template <
typename Archive>
void serialize(
const Archive& ar) {}
2734 template <
typename opT>
2741 const keyT& key = it->first;
2742 nodeT& node = it->second;
2758 template <
typename Archive>
void serialize(
const Archive& ar) {}
2761 template <
typename Q,
typename R>
2769 std::vector<unsigned int> ind(vleft.size());
2770 for (
unsigned int i=0; i<vleft.size(); ++i) {
2773 for (
unsigned int i=0; i<vleft.size(); ++i) {
2775 std::swap(ind[i],ind[j]);
2780 if (it->second.has_coeff()) {
2786 for (
unsigned int j=0; j<vleft.size(); ++j) {
2787 unsigned int i = ind[j];
2789 implT* left = vleft[i].get();
2792 if (newnode && key.
level()>0) {
2800 nodeT& node = acc->second;
2817 const std::vector<tensorT>&
c,
2824 template <
typename opT>
2826 std::vector<tensorT>
c(
v.size());
2827 for (
unsigned int i=0; i<
v.size(); i++) {
2830 c[i]=
cc.full_tensor();
2841 template <
typename opT>
2844 for (std::size_t i=1; i<
v.size(); ++i) {
2845 if (
v[i] and
v[i-1]) {
2851 const keyT& key = it->first;
2852 if (it->second.has_coeff())
2853 world.
taskq.
add(*
this, &implT:: template multiop_values_doit<opT>, key,
op,
v);
2866 template <
typename opT>
2868 const std::vector<implT*>& vin, std::vector<implT*>& vout) {
2869 std::vector<tensorT>
c(vin.size());
2870 for (
unsigned int i=0; i<vin.size(); i++) {
2873 c[i]=
cc.full_tensor();
2876 std::vector<tensorT> r =
op(key,
c);
2878 for (std::size_t i=0; i<vout.size(); ++i) {
2889 template <
typename opT>
2891 std::vector<implT*>& vout,
const bool fence=
true) {
2893 for (std::size_t i=1; i<vin.size(); ++i) {
2894 if (vin[i] and vin[i-1]) {
2900 const keyT& key = it->first;
2901 if (it->second.has_coeff())
2902 world.
taskq.
add(*
this, &implT:: template multi_to_multi_op_values_doit<opT>,
2903 key,
op, vin, vout);
2906 for (
implT* it2 : vout) {
2918 template <
typename Q,
typename R>
2924 for (
unsigned int j=0; j<vright.size(); ++j) {
2925 world.
taskq.
add(*
this, &implT:: template vtransform_doit<Q,R>, vright[j],
copy(
c(j,
_)), vleft, tol);
2933 template <
typename opT>
2953 template <
typename L,
typename R>
2963 double lnorm = 1e99;
2965 if (lc.
size() == 0) {
2968 lnorm = it->second.get_norm_tree();
2969 if (it->second.has_coeff())
2970 lc = it->second.coeff().full_tensor_copy();
2974 std::vector<FunctionImpl<T,NDIM>*> vresult;
2975 std::vector<const FunctionImpl<R,NDIM>*> vright;
2976 std::vector< Tensor<R> > vrc;
2977 vresult.reserve(vrightin.size());
2978 vright.reserve(vrightin.size());
2979 vrc.reserve(vrightin.size());
2981 for (
unsigned int i=0; i<vrightin.size(); ++i) {
2986 if (rc.
size() == 0) {
2989 rnorm = it->second.get_norm_tree();
2990 if (it->second.has_coeff())
2991 rc = it->second.coeff().full_tensor_copy();
2998 result->
task(
world.
rank(), &implT:: template do_mul<L,R>, key, lc, std::make_pair(key,rc));
3000 else if (tol && lnorm*rnorm <
truncate_tol(tol, key)) {
3005 vresult.push_back(result);
3006 vright.push_back(right);
3011 if (vresult.size()) {
3019 std::vector< Tensor<R> > vrss(vresult.size());
3020 for (
unsigned int i=0; i<vresult.size(); ++i) {
3021 if (vrc[i].
size()) {
3024 vrss[i] = vright[i]->unfilter(rd);
3029 const keyT& child = kit.key();
3037 std::vector< Tensor<R> > vv(vresult.size());
3038 for (
unsigned int i=0; i<vresult.size(); ++i) {
3040 vv[i] =
copy(vrss[i](cp));
3043 woT::task(
coeffs.
owner(child), &implT:: template mulXXveca<L,R>, child, left, ll, vright, vv, vresult, tol);
3057 template <
typename L,
typename R>
3065 double lnorm=1e99, rnorm=1e99;
3068 if (lc.
size() == 0) {
3071 lnorm = it->second.get_norm_tree();
3072 if (it->second.has_coeff())
3073 lc = it->second.coeff().reconstruct_tensor();
3077 if (rc.
size() == 0) {
3080 rnorm = it->second.get_norm_tree();
3081 if (it->second.has_coeff())
3082 rc = it->second.coeff().reconstruct_tensor();
3087 do_mul<L,R>(key, lc, std::make_pair(key,rc));
3120 const keyT& child = kit.key();
3128 woT::task(
coeffs.
owner(child), &implT:: template mulXXa<L,R>, child, left, ll, right, rr, tol);
3143 template <
typename L,
typename R,
typename opT>
3152 if (lc.
size() == 0) {
3155 if (it->second.has_coeff())
3156 lc = it->second.coeff().reconstruct_tensor();
3160 if (rc.
size() == 0) {
3163 if (it->second.has_coeff())
3164 rc = it->second.coeff().reconstruct_tensor();
3168 do_binary_op<L,R>(key, lc, std::make_pair(key,rc),
op);
3190 const keyT& child = kit.key();
3202 template <
typename Q,
typename opT>
3221 template <
typename Archive>
3235 template <
typename Q,
typename opT>
3240 const Tensor<Q> fc =
func->coeffs.find(key).get()->second.coeff().reconstruct_tensor();
3242 if (fc.
size() == 0) {
3246 const keyT& child = kit.key();
3260 template <
typename L,
typename R>
3274 template <
typename L,
typename R,
typename opT>
3276 const opT&
op,
bool fence) {
3288 template <
typename Q,
typename opT>
3301 template <
typename Q,
typename opT>
3317 template <
typename L,
typename R>
3323 std::vector< Tensor<R> > vr(vright.size());
3391 const coordT& plotlo,
const coordT& plothi,
const std::vector<long>& npt,
3392 bool eval_refine)
const;
3402 const std::vector<long>& npt,
3403 const bool eval_refine =
false)
const;
3490 template<
size_t LDIM>
3517 double glo=0.0, ghi=0.0, flo=0.0, fhi=0.0;
3521 double total_hi=glo*fhi + ghi*flo + fhi*ghi;
3541 coeffT coeff1=
f.get_impl()->parent_to_child(
f.coeff(),
f.key(),key);
3549 bool is_leaf=
screen(coeff1_2D,coeff2,key);
3550 if (key.
level()<2) is_leaf=
false;
3556 coeffT hvalues=
f.get_impl()->coeffs2values(key,coeff1_2D);
3569 return std::pair<bool,coeffT> (is_leaf,hcoeff);
3593 template <
typename Archive>
void serialize(
const Archive& ar) {
3619 bool is_leaf=(
f.is_leaf() and
g.is_leaf());
3620 if (not is_leaf)
return std::pair<bool,coeffT> (is_leaf,
coeffT());
3622 coeffT fcoeff=
f.get_impl()->parent_to_child(
f.coeff(),
f.key(),key);
3623 coeffT gcoeff=
g.get_impl()->parent_to_child(
g.coeff(),
g.key(),key);
3626 hcoeff.
reduce_rank(
f.get_impl()->get_tensor_args().thresh);
3627 return std::pair<bool,coeffT> (is_leaf,hcoeff);
3647 template <
typename Archive>
void serialize(
const Archive& ar) {
3660 template<
size_t LDIM>
3667 coeff_opT coeff_op(
this,ff,gg,
particle);
3670 apply_opT apply_op(
this);
3675 woT::task(
p, &implT:: template forward_traverse<coeff_opT,apply_opT>, coeff_op, apply_op,
key0);
3682 template<
size_t LDIM,
typename leaf_opT>
3710 if (not is_leaf)
return std::pair<bool,coeffT> (is_leaf,
coeffT());
3720 return std::pair<bool,coeffT>(is_leaf,coeff);
3743 template <
typename Archive>
void serialize(
const Archive& ar) {
3754 template<
typename coeff_opT,
typename apply_opT>
3758 woT::task(
world.
rank(), &implT:: template traverse_tree<coeff_opT,apply_opT>, active_coeff, apply_op, key);
3768 template<
typename coeff_opT,
typename apply_opT>
3772 typedef typename std::pair<bool,coeffT> argT;
3773 const argT
arg=coeff_op(key);
3774 apply_op.operator()(key,
arg.second,
arg.first);
3776 const bool has_children=(not
arg.first);
3779 const keyT& child=kit.key();
3780 coeff_opT child_op=coeff_op.make_child(child);
3784 void (
implT::*ft)(
const coeff_opT&,
const apply_opT&,
const keyT&)
const = &implT::forward_traverse<coeff_opT,apply_opT>;
3798 template<std::
size_t LDIM,
typename leaf_opT>
3801 const leaf_opT&
leaf_op,
bool fence) {
3802 MADNESS_CHECK_THROW(p1.size()==p2.size(),
"hartree_product: p1 and p2 must have the same size");
3803 for (
auto&
p : p1)
MADNESS_CHECK(
p->is_nonstandard() or
p->is_nonstandard_with_leaves());
3804 for (
auto&
p : p2)
MADNESS_CHECK(
p->is_nonstandard() or
p->is_nonstandard_with_leaves());
3808 for (std::size_t i=0; i<p1.size(); ++i) {
3817 coeff_opT coeff_op(
this,iap1,iap2,
leaf_op);
3822 apply_opT apply_op(
this);
3825 coeff_op, apply_op,
cdata.key0);
3835 template <
typename opT,
typename R>
3840 const double cnorm =
c.normf();
3849 int maxdir = s ? 1 : -1;
3850 for (
int direction=-1; direction<=maxdir; direction+=2) {
3851 lnew[
axis] = lold + direction*s;
3852 if (lnew[
axis] >= 0 && lnew[
axis] < maxs) {
3854 double Rnorm = r.
normf();
3860 if (s <= 1 || r.
normf()*cnorm > tol) {
3864 if (result.
normf() > tol*0.3) {
3886 template <
typename opT,
typename R>
3893 fiterT end =
f->coeffs.end();
3895 for (fiterT it=
f->coeffs.begin(); it!=end; ++it) {
3896 const fnodeT& node = it->second;
3897 if (node.has_coeff()) {
3898 const keyT& key = it->first;
3899 const Tensor<R>&
c = node.coeff().full_tensor_copy();
3900 woT::task(
me, &implT:: template apply_1d_realspace_push_op<opT,R>,
3910 const std::pair<keyT,coeffT>& left,
3911 const std::pair<keyT,coeffT>& center,
3912 const std::pair<keyT,coeffT>& right);
3917 const std::pair<keyT,coeffT>& left,
3918 const std::pair<keyT,coeffT>& center,
3919 const std::pair<keyT,coeffT>& right);
3968 template<std::
size_t LDIM>
3994 bool use_tnorm=
false;
3999 tensorT val_rhs=fcf.coeffs2values(key, coeff_rhs);
4001 return fcf.values2coeffs(key,val_rhs);
4010 coeff1(
cdata.s0)=coeff_rhs;
4014 tensorT coeff_lhs_k1(cdata_npt.vk);
4019 val_lhs_k1.
emul(val_rhs_k1);
4026 result1(
cdata.s0)=0.0;
4036 const long k=coeff_rhs.
dim(0);
4050 coeff_rhs_npt1(fcf_lo.
cdata.s0)=coeff_rhs;
4064 val_lhs_npt.
emul(val_rhs);
4071 result1(
cdata.s0)=0.0;
4076 template <
typename Archive>
void serialize(
const Archive& ar) {
4089 template<
typename opT,
size_t LDIM>
4130 if(
leaf_op.do_pre_screening()){
4132 if(
leaf_op.pre_screening(key)){
4136 return std::pair<bool,coeffT> (
true,
coeffT());
4147 if(key.
level()<
int(il)){
4159 if(
leaf_op.post_screening(key,sum_coeff)){
4161 return std::pair<bool,coeffT> (
true,
coeffT());
4167 return std::pair<bool,coeffT> (
true,
coeffT());
4171 std::vector<bool> child_is_leaf(1<<
NDIM,
false);
4186 keyT child=kit.key();
4187 bool is_leaf=child_is_leaf[i];
4205 return std::pair<bool,coeffT> (
true,
coeffT());
4235 double dnorm_ket, snorm_ket;
4237 snorm_ket=
iaket.coeff(key).normf();
4238 dnorm_ket=
iaket.dnorm(key);
4245 dnorm_ket=s1*d2 + s2*d1 + d1*d2;
4251 error+=snorm*dnorm_ket + dnorm*snorm_ket + dnorm*dnorm_ket;
4256 error+=snorm*dnorm_ket + dnorm*snorm_ket + dnorm*dnorm_ket;
4260 double snorm=s_coeffs.
normf();
4263 double dnorm=
d.normf();
4264 error+=snorm*dnorm_ket + dnorm*snorm_ket + dnorm*dnorm_ket;
4296 double error=refine_error;
4324 return std::make_pair(cresult,
error);
4346 iaket1,iap11,iap21,iav11,iav21,
eri);
4350 const ctL& iap11,
const ctL& iap21,
const ctL& iav11,
const ctL& iav21,
4351 const implT* eri1) {
4356 template <
typename Archive>
void serialize(
const Archive& ar) {
4368 template<
typename opT>
4371 constexpr size_t LDIM=
NDIM/2;
4378 std::shared_ptr< FunctionFunctorInterface<T,NDIM> > func2(this->
get_functor());
4386 if (fence)
func->make_redundant(
true);
4390 for (
auto& ket :
func->impl_ket_vector) {
4399 for (std::size_t i=0; i<
func->impl_p1_vector.size(); ++i) {
4429 template<
typename opT, std::
size_t LDIM>
4434 const bool fence=
true) {
4445 coeff_opT coeff_op(
this,
leaf_op,iaket,iap1,iap2,iav1,iav2,eri);
4453 coeff_op, apply_op,
cdata.key0);
4462 void mapdim(
const implT&
f,
const std::vector<long>& map,
bool fence);
4472 const std::vector<long>&
mirror,
bool fence);
4505 auto& node=it->second;
4506 node.recompute_snorm_and_dnorm(
cdata);
4576 template <
typename opT>
4583 nodeT& node = acc->second;
4591 const keyT& child = kit.key();
4601 template <
typename opT>
4614 template <
typename opT>
4627 void broaden_op(
const keyT& key,
const std::vector< Future <bool> >&
v);
4731 const keyT& key = it->first;
4732 nodeT& node = it->second;
4746 template <
typename Archive>
void serialize(
const Archive& ar) {
4753 template<
size_t OPDIM>
4762 template <
class Archive>
4773 template <
typename opT,
typename R,
size_t OPDIM>
4801 template <
typename opT,
typename R,
size_t OPDIM>
4839 template <
typename opT,
typename R,
size_t OPDIM>
4844 if (2*OPDIM==
NDIM) result=
op->apply2_lowdim(args.
key, args.
d, coeff,
4846 if (OPDIM==
NDIM) result =
op->apply2(args.
key, args.
d, coeff,
4849 const double result_norm=result.
svd_normf();
4851 if (result_norm> 0.3*args.
tol/args.
fac) {
4881 template <
typename opT,
typename R>
4893 typedef typename opT::keyT opkeyT;
4894 constexpr auto opdim = opT::opdim;
4895 const opkeyT
source =
op->get_source_key(key);
4913 double radius = 1.5 + 0.33 * std::max(0.0, 2 - std::log10(
thresh) -
4919 double cnorm =
c.normf();
4926 (
op->particle() == 1)
4928 op->func_domain_is_periodic())
4930 op->func_domain_is_periodic());
4932 const auto default_real_distance_squared = [&](
const auto &
displacement)
4936 const auto default_lattice_distance_squared = [&](
const auto &
displacement)
4940 const auto default_skip_predicate = [&](
const auto &
displacement)
4944 const auto for_each = [&](
const auto &displacements,
4945 const auto &real_distance_squared,
4946 const auto &lattice_distance_squared,
4947 const auto &skip_predicate) -> std::optional<double> {
4963 std::optional<double> real_last_distsq;
4964 std::optional<std::uint64_t> lattice_last_distsq;
4969 const auto &probing_displacement =
4970 displacements.probing_displacement();
4971 const double opnorm =
4973 if (cnorm * opnorm <= tol / fac) {
4984 if (
op->particle() == 1)
4993 const auto real_distsq = real_distance_squared(
displacement);
4994 const std::uint64_t lattice_distsq = real_distsq ? 0 : lattice_distance_squared(
displacement);
4995 if (!real_last_distsq.has_value() ||
4996 !
nearlyEqual(real_distsq, *real_last_distsq) || (
nearlyEqual(*real_last_distsq, 0) && lattice_distsq != *lattice_last_distsq)) {
4997 if (nvalid > 0 && nused == 0 && (real_distsq > 0 || lattice_distsq > 1)) {
5006 real_last_distsq = real_distsq;
5008 lattice_last_distsq = real_distsq ? std::optional<std::uint64_t>{} : lattice_distsq;
5011 keyT dest =
neighbor(key,
d, func_is_treated_by_op_as_periodic);
5016 if (cnorm * opnorm > tol / fac) {
5019 if (result.
normf() > 0.3 * tol / fac) {
5032 return real_last_distsq;
5039 const std::vector<opkeyT> &disp =
op->get_disp(key.
level());
5040 const auto max_distsq_reached = for_each(disp, default_real_distance_squared, default_lattice_distance_squared, default_skip_predicate);
5045 if (
op->range_restricted() && key.
level() >= 1) {
5047 std::array<std::optional<std::int64_t>, opdim> box_radius;
5048 std::array<std::optional<std::int64_t>, opdim> surface_thickness;
5049 auto &
range =
op->get_range();
5050 for (
int d = 0;
d != opdim; ++
d) {
5053 surface_thickness[
d] =
range[
d].finite_soft() ? 1 : 0;
5060 if (max_distsq_reached)
5064 auto opkey =
op->particle() == 1 ? key.template extract_front<opdim>() : key.template extract_front<opdim>();
5066 range_boundary_face_displacements(opkey, box_radius,
5068 op->lattice_summed(),
5071 range_boundary_face_displacements,
5074 [](
const auto &
displacement) -> std::uint64_t {
return 0; },
5075 default_skip_predicate);
5081 template <
typename opT,
typename R>
5085 for (
const auto& [key, node]:
f.coeffs) {
5086 if (node.has_coeff()) {
5087 if (node.coeff().dim(0) !=
k ||
op.doleaves) {
5090 woT::task(
p, &implT:: template do_apply<opT,R>, &
op, key, node.coeff().reconstruct_tensor());
5114 template <
typename opT,
typename R>
5116 const bool& do_kernel) {
5119 typedef typename opT::keyT opkeyT;
5122 std::list<opkeyT> blacklist;
5124 constexpr auto opdim=opT::opdim;
5128 const opkeyT
source=
op->get_source_key(key);
5133 double fac=std::pow(3,
NDIM*0.5);
5134 double cnorm = coeff.
normf();
5138 apply_targs.
thresh=tol/fac*0.03;
5148#ifdef HAVE_GENTENSOR
5157 for (
const auto&
d: disp) {
5158 const int shell=
d.distsq_bc(
op->lattice_summed());
5159 if (do_kernel and (shell>0))
break;
5160 if ((not do_kernel) and (shell==0))
continue;
5176 bool screened=
false;
5177 typename std::list<opkeyT>::const_iterator it2;
5178 for (it2=blacklist.begin(); it2!=blacklist.end(); it2++) {
5179 if (
d.is_farther_out_than(*it2)) {
5189 if (cnorm*opnorm> tol/fac) {
5191 double cost_ratio=
op->estimate_costs(
source,
d, coeff_SVD, tol/fac/cnorm, tol/fac);
5195 if (cost_ratio>0.0) {
5199 if (cost_ratio<1.0) {
5203 if (2*opdim==
NDIM) {
5209 maxnorm=std::max(
norm,maxnorm);
5212 }
else if (shell >= 12) {
5215 if (
norm<0.3*tol/fac) blacklist.push_back(
d);
5223 template <
typename opT,
typename R>
5232 const keyT& key = it->first;
5233 const coeffT& coeff = it->second.coeff();
5237 woT::task(
p, &implT:: template do_apply_directed_screening<opT,R>, &
op, key, coeff,
true);
5238 woT::task(
p, &implT:: template do_apply_directed_screening<opT,R>, &
op, key, coeff,
false);
5264 template<
typename opT, std::
size_t LDIM>
5277 coeff_opT coeff_op(
this,ff,gg,&apply_op);
5283 woT::task(
p, &implT:: template forward_traverse<coeff_opT,apply_opT>, coeff_op, apply_op,
key0);
5291 template<
typename opT, std::
size_t LDIM>
5332 bool is_leaf=
leaf_op(key,fcoeff,gcoeff);
5346 result->
task(
p,&implT:: template do_apply_directed_screening<opT,T>,
5352 return std::pair<bool,coeffT> (is_leaf,
coeffT());
5358 const coeffT& coeff)
const {
5361 if (key.
level()<2) is_leaf=
false;
5362 return std::pair<bool,coeffT> (is_leaf,coeff);
5383 const opT* apply_op1) {
5387 template <
typename Archive>
void serialize(
const Archive& ar) {
5398 template<
typename opT>
5408 coeff_opT coeff_op(
this,fimpl,&apply_op);
5414 coeff_op, apply_op,
cdata.key0);
5422 template<
typename opT>
5428 typedef std::pair<bool,coeffT>
argT;
5456 result->
task(
p,&implT:: template do_apply_directed_screening<opT,T>,
5462 if (
iaf.is_leaf())
return argT(
true,coeff);
5466 const bool is_leaf=
true;
5476 if (key.
level()<2) is_leaf=
false;
5477 return argT(is_leaf,coeff);
5499 return this_type(result1,iaf1,apply_op1);
5502 template <
typename Archive>
void serialize(
const Archive& ar) {
5511 template <
typename opT>
5516 std::vector<long> vq(
NDIM);
5517 for (std::size_t i=0; i<
NDIM; ++i)
5519 tensorT fval(vq,
false), work(vq,
false), result(vq,
false);
5537 double err = fval.normf();
5541 template <
typename opT>
5560 const keyT& key = it->first;
5561 const nodeT& node = it->second;
5572 template <
typename Archive>
5579 template <
typename opT>
5583 const int npt =
cdata.npt + 1;
5598 const nodeT& node = it->second;
5612 template <
typename Archive>
void serialize(
const Archive& ar) {
5622 template<
typename R>
5633 const keyT& key=it->first;
5634 const nodeT& fnode = it->second;
5641 MADNESS_EXCEPTION(
"functions have different k or compress/reconstruct error", 0);
5660 template <
typename Archive>
void serialize(
const Archive& ar) {
5668 template <
typename R>
5683 template<
typename R>
5695 constexpr std::size_t LDIM=std::max(
NDIM/2,std::size_t(1));
5697 const keyT& key=it->first;
5698 const nodeT& fnode = it->second;
5699 if (not fnode.
has_coeff())
return resultT(0.0);
5702 auto find_valid_parent = [](
auto& key,
auto& impl,
auto&& find_valid_parent) {
5703 MADNESS_CHECK(impl->get_coeffs().owner(key)==impl->world.rank());
5704 if (impl->get_coeffs().probe(key))
return key;
5705 auto parentkey=key.
parent();
5706 return find_valid_parent(parentkey, impl, find_valid_parent);
5710 auto get_coeff = [&find_valid_parent](
const auto& key,
const auto& v_impl) {
5711 if ((v_impl.size()>0) and v_impl.front().get()) {
5712 auto impl=v_impl.front();
5716 auto parentkey = find_valid_parent(key, impl, find_valid_parent);
5718 typename decltype(impl->coeffs)::accessor acc;
5719 impl->get_coeffs().find(acc,parentkey);
5720 auto parentcoeff=acc->second.coeff();
5721 auto coeff=impl->parent_to_child(parentcoeff, parentkey, key);
5725 typedef typename std::decay_t<
decltype(v_impl)>::value_type::element_type::typeT S;
5732 auto make_vector = [](
auto&
arg) {
5733 return std::vector<std::decay_t<
decltype(
arg)>>(1,
arg);
5744 "only one ket function supported in inner_on_demand");
5746 "only one p1 function supported in inner_on_demand");
5748 "only one p2 function supported in inner_on_demand");
5749 auto coeff_bra=fnode.
coeff();
5750 auto coeff_ket=get_coeff(key,
func->impl_ket_vector);
5751 auto coeff_v1=get_coeff(key1,make_vector(
func->impl_m1));
5752 auto coeff_v2=get_coeff(key2,make_vector(
func->impl_m2));
5753 auto coeff_p1=get_coeff(key1,
func->impl_p1_vector);
5754 auto coeff_p2=get_coeff(key2,
func->impl_p2_vector);
5758 if (coeff_ket.has_data() and coeff_p1.has_data()) {
5762 }
else if (coeff_ket.has_data() or coeff_p1.has_data()) {
5763 coeff_ket = (coeff_ket.has_data()) ? coeff_ket :
outer(coeff_p1,coeff_p2);
5770 if (coeff_v1.has_data()) {
5772 v1v2ket = pm(key,coeff_v1.full_tensor(), 1);
5774 v1v2ket+= pm(key,coeff_v2.full_tensor(), 2);
5777 v1v2ket = coeff_ket;
5781 if (
func->impl_eri) {
5785 tensorT braket=pm(key,coeff_bra.full_tensor_copy().conj());
5791 result=coeff_bra.full_tensor_copy().trace_conj(v1v2ket.
full_tensor_copy());
5800 template <
typename Archive>
void serialize(
const Archive& ar) {
5808 template <
typename R>
5820 template<
typename R>
5831 const keyT& key=it->first;
5832 const nodeT& fnode = it->second;
5839 MADNESS_EXCEPTION(
"functions have different k or compress/reconstruct error", 0);
5858 template <
typename Archive>
void serialize(
const Archive& ar) {
5866 template <
typename R>
5880 typedef std::vector< std::pair<int,const coeffT*> >
mapvecT;
5889 typename mapT::accessor acc;
5890 const keyT& key = it->first;
5893 [[maybe_unused]]
auto inserted = map->insert(acc,key);
5894 acc->second.push_back(std::make_pair(index,&(node.
coeff())));
5907 for (
unsigned int i=0; i<
v.size(); i++) {
5911 if (
v.size())
v[0]->world.taskq.fence();
5917 template <
typename R>
5919 const typename mapT::iterator lend,
5926 for (
typename mapT::iterator lit=lstart; lit!=lend; ++lit) {
5927 const keyT& key = lit->first;
5929 if (rit != rmap_ptr->end()) {
5930 const mapvecT& leftv = lit->second;
5932 const int nleft = leftv.
size();
5933 const int nright= rightv.
size();
5935 for (
int iv=0; iv<nleft; iv++) {
5936 const int i = leftv[iv].first;
5939 for (
int jv=0; jv<nright; jv++) {
5940 const int j = rightv[jv].first;
5943 if (!sym || (sym && i<=j))
5944 r(i,j) += iptr->trace_conj(*jptr);
5954 template <
typename R>
5956 const typename mapT::iterator lend,
5963 for (
typename mapT::iterator lit=lstart; lit!=lend; ++lit) {
5964 const keyT& key = lit->first;
5966 if (rit != rmap_ptr->end()) {
5967 const mapvecT& leftv = lit->second;
5969 const size_t nleft = leftv.
size();
5970 const size_t nright= rightv.
size();
5972 unsigned int size = leftv[0].second->size();
5976 for(
unsigned int iv = 0; iv < nleft; ++iv) Left(iv,
_) = (*(leftv[iv].second)).full_tensor();
5977 for(
unsigned int jv = 0; jv < nright; ++jv) Right(jv,
_) = (*(rightv[jv].second)).full_tensor();
5982 for(
unsigned int iv = 0; iv < nleft; ++iv) {
5983 const int i = leftv[iv].first;
5984 for(
unsigned int jv = 0; jv < nright; ++jv) {
5985 const int j = rightv[jv].first;
5986 if (!sym || (sym && i<=j)) result(i,j) += r(iv,jv);
5997 template <
typename R,
typename = std::enable_if_t<std::is_
floating_po
int_v<R>>>
5998 static void do_dot_localX(
const typename mapT::iterator lstart,
5999 const typename mapT::iterator lend,
6007 for (
typename mapT::iterator lit = lstart; lit != lend; ++lit) {
6008 const keyT& key = lit->first;
6010 if (rit != rmap_ptr->end()) {
6011 const mapvecT& leftv = lit->second;
6013 const int nleft = leftv.
size();
6014 const int nright = rightv.
size();
6016 for (
int iv = 0; iv < nleft; iv++) {
6017 const int i = leftv[iv].first;
6020 for (
int jv = 0; jv < nright; jv++) {
6021 const int j = rightv[jv].first;
6024 if (!sym || (sym && i <= j))
6025 r(i, j) += iptr->trace_conj(*jptr);
6035 template <
typename R>
6037 const typename mapT::iterator lend,
6044 for (
typename mapT::iterator lit = lstart; lit != lend; ++lit) {
6045 const keyT& key = lit->first;
6047 if (rit != rmap_ptr->end()) {
6048 const mapvecT& leftv = lit->second;
6050 const size_t nleft = leftv.
size();
6051 const size_t nright= rightv.
size();
6053 unsigned int size = leftv[0].second->size();
6057 for(
unsigned int iv = 0; iv < nleft; ++iv) Left(iv,
_) = (*(leftv[iv].second)).full_tensor();
6058 for(
unsigned int jv = 0; jv < nright; ++jv) Right(jv,
_) = (*(rightv[jv].second)).full_tensor();
6062 for(
unsigned int iv = 0; iv < nleft; ++iv) {
6063 const int i = leftv[iv].first;
6064 for(
unsigned int jv = 0; jv < nright; ++jv) {
6065 const int j = rightv[jv].first;
6066 if (!sym || (sym && i <= j)) result(i, j) += r(iv, jv);
6075 template <
typename Real>
6076 static std::enable_if_t<std::is_floating_point_v<Real>, Real>
conj(
const Real x) {
6080 template <
typename Real>
6081 static std::complex<Real>
conj(
const std::complex<Real>& x) {
6082 return std::conj(x);
6085 template <
typename R>
6111 size_t chunk = (lmap.size()-1)/(3*4*5)+1;
6116 typename mapT::iterator lstart=lmap.begin();
6117 while (lstart != lmap.end()) {
6118 typename mapT::iterator lend = lstart;
6119 advance(lend,chunk);
6123 left[0]->world.taskq.fence();
6126 for (
long i=0; i<r.
dim(0); i++) {
6127 for (
long j=0; j<i; j++) {
6137 template <
typename R>
6163 size_t chunk = (lmap.size() - 1) / (3 * 4 * 5) + 1;
6168 typename mapT::iterator lstart=lmap.begin();
6169 while (lstart != lmap.end()) {
6170 typename mapT::iterator lend = lstart;
6171 advance(lend, chunk);
6175 left[0]->world.taskq.fence();
6179 for (
long i = 0; i < r.
dim(0); i++) {
6180 for (
long j = 0; j < i; j++) {
6190 template <
typename R>
6193 static_assert(!std::is_same<R, int>::value &&
6194 std::is_same<R, int>::value,
6195 "Compilation failed because you wanted to know the type; see below:");
6205 template<
typename Q, std::size_t LDIM,
typename R, std::size_t KDIM,
6206 std::size_t CDIM = (KDIM + LDIM -
NDIM) / 2>
6208 const std::array<int, CDIM> v1,
const std::array<int, CDIM> v2) {
6210 typedef std::multimap<Key<NDIM>, std::list<Key<CDIM>>> contractionmapT;
6224 std::list<contractionmapT> all_contraction_maps;
6225 for (std::size_t n=0; n<nmax; ++n) {
6230 auto [h_ijlist, h_jlist] =
h.get_contraction_node_lists(n, v2);
6231 if ((g_ijlist.size() == 0) and (h_ijlist.size() == 0))
break;
6241 bool this_first =
true;
6245 h_ijlist, h_jlist, this_first,
thresh);
6251 h_nc.
key0(), hnode0, v2, v1,
6252 g_ijlist, g_jlist, this_first,
thresh);
6255 contraction_map.merge(contraction_map1);
6257 auto it = contraction_map.begin();
6258 while (it != contraction_map.end()) {
6259 auto it_end = contraction_map.upper_bound(it->first);
6262 while (it2 != it_end) {
6263 it->second.splice(it->second.end(), it2->second);
6264 it2 = contraction_map.erase(it2);
6272 for (
auto& elem: contraction_map) {
6274 elem.second.unique();
6282 all_contraction_maps.push_back(contraction_map);
6284 long mapsize=contraction_map.
size();
6285 if (mapsize==0)
break;
6290 for (
const auto& contraction_map : all_contraction_maps) {
6291 for (
const auto& key_list : contraction_map) {
6293 const std::list<Key<CDIM>>& list=key_list.second;
6295 &
g,&
h,v1,v2,key,list);
6307 template<std::
size_t CDIM>
6308 std::tuple<std::set<Key<NDIM>>, std::map<Key<CDIM>,
double>>
6312 auto has_d_coeffs = [&
cdata](
const coeffT& coeff) {
6313 if (coeff.has_no_data())
return false;
6314 return (coeff.dim(0)==2*
cdata.k);
6318 std::set<Key<NDIM>> ij_list;
6319 std::map<Key<CDIM>,
double> j_list;
6324 if ((key.
level()==
int(n)) and (has_d_coeffs(node.
coeff()))) {
6325 ij_list.insert(key);
6327 for (std::size_t i=0; i<CDIM; ++i) j_trans[i]=key.
translation()[
v[i]];
6329 const double max_d_norm=j_list[jkey];
6330 j_list.insert_or_assign(jkey,std::max(max_d_norm,node.
get_dnorm()));
6332 while (j_list.count(parent_jkey)==0) {
6333 j_list.insert({parent_jkey,1.0});
6334 parent_jkey=parent_jkey.
parent();
6338 return std::make_tuple(ij_list,j_list);
6361 template<std::size_t CDIM, std::size_t ODIM, std::size_t FDIM=
NDIM+ODIM-2*CDIM>
6364 const std::array<int,CDIM>& v_this,
6365 const std::array<int,CDIM>& v_other,
6366 const std::set<
Key<ODIM>>& ij_other_list,
6367 const std::map<
Key<CDIM>,
double>& j_other_list,
6368 bool this_first,
const double thresh) {
6370 std::multimap<Key<FDIM>, std::list<Key<CDIM>>> contraction_map;
6373 if (j_other_list.empty())
return contraction_map;
6380 const double max_d_norm=j_other_list.find(j_this_key)->second;
6386 bool final_scale=key.
level()==ij_other_list.begin()->level();
6387 if (final_scale and sd_norm_product_large) {
6388 for (
auto& other_key : ij_other_list) {
6389 const auto j_other_key=other_key.extract_key(v_other);
6390 if (j_this_key != j_other_key)
continue;
6392 auto k_key=other_key.extract_complement_key(v_other);
6398 contraction_map.insert(std::make_pair(ik_key,std::list<
Key<CDIM>>{j_this_key}));
6400 return contraction_map;
6403 bool continue_recursion = (j_other_list.count(j_this_key)==1);
6404 if (not continue_recursion)
return contraction_map;
6408 continue_recursion = (node.
has_children() or sd_norm_product_large);
6410 if (continue_recursion) {
6412 bool compute_child_s_coeffs=
true;
6417 keyT child=kit.key();
6422 bool need_s_coeffs= childnode_exists ? (acc->second.get_snorm()<=0.0) :
true;
6425 if (need_s_coeffs) {
6426 if (compute_child_s_coeffs) {
6427 if (
d.dim(0)==
cdata.vk[0]) {
6433 compute_child_s_coeffs=
false;
6439 if (not childnode_exists) {
6442 }
else if (childnode_exists and need_s_coeffs) {
6443 acc->second.coeff()=child_s_coeffs;
6447 nodeT& childnode = acc->second;
6451 ij_other_list, j_other_list, this_first,
thresh));
6457 return contraction_map;
6469 template<
typename Q, std::size_t LDIM,
typename R, std::size_t KDIM,
6470 std::size_t CDIM = (KDIM + LDIM -
NDIM) / 2>
6472 const std::array<int, CDIM> v1,
const std::array<int, CDIM> v2,
6475 Key<LDIM - CDIM> i_key;
6476 Key<KDIM - CDIM> k_key;
6480 for (
const auto& j_key: j_key_list) {
6482 auto v_complement = [](
const auto&
v,
const auto& vc) {
6483 constexpr std::size_t VDIM = std::tuple_size<std::decay_t<
decltype(
v)>>::value;
6484 constexpr std::size_t VCDIM = std::tuple_size<std::decay_t<
decltype(vc)>>::value;
6485 std::array<int, VCDIM> result;
6486 for (std::size_t i = 0; i < VCDIM; i++) result[i] = (
v.back() + i + 1) % (VDIM + VCDIM);
6489 auto make_ij_key = [&v_complement](
const auto i_key,
const auto j_key,
const auto&
v) {
6490 constexpr std::size_t IDIM = std::decay_t<
decltype(i_key)>::static_size;
6491 constexpr std::size_t JDIM = std::decay_t<
decltype(j_key)>::static_size;
6492 static_assert(JDIM == std::tuple_size<std::decay_t<
decltype(
v)>>::value);
6495 for (std::size_t i = 0; i <
v.size(); ++i) l[
v[i]] = j_key.translation()[i];
6496 std::array<int, IDIM> vc1;
6497 auto vc = v_complement(
v, vc1);
6498 for (std::size_t i = 0; i < vc.size(); ++i) l[vc[i]] = i_key.translation()[i];
6503 Key<LDIM> ij_key = make_ij_key(i_key, j_key, v1);
6504 Key<KDIM> jk_key = make_ij_key(k_key, j_key, v2);
6508 const coeffT& gcoeff =
g->get_coeffs().find(ij_key).get()->second.coeff();
6509 const coeffT& hcoeff =
h->get_coeffs().find(jk_key).get()->second.coeff();
6511 if (gcoeff.
dim(0) ==
g->get_cdata().k) {
6512 gcoeff1 =
coeffT(
g->get_cdata().v2k,
g->get_tensor_args());
6513 gcoeff1(
g->get_cdata().s0) += gcoeff;
6517 if (hcoeff.
dim(0) ==
g->get_cdata().k) {
6518 hcoeff1 =
coeffT(
h->get_cdata().v2k,
h->get_tensor_args());
6519 hcoeff1(
h->get_cdata().s0) += hcoeff;
6525 auto fuse = [](
Tensor<T> tensor,
const std::array<int, CDIM>&
v,
int offset) {
6526 for (std::size_t i = 0; i < CDIM - 1; ++i) {
6536 auto contract2 = [](
const auto& svdcoeff,
const auto& tensor,
const int particle) {
6538 const int spectator_particle=(
particle+1)%2;
6539 Tensor<Q> gtensor = svdcoeff.get_svdtensor().make_vector_with_weights(
particle);
6540 gtensor=gtensor.
reshape(svdcoeff.rank(),gtensor.
size()/svdcoeff.rank());
6542 Tensor<Q> gtensor_other = svdcoeff.get_svdtensor().ref_vector(spectator_particle);
6559 if (key.
level() > 0) {
6562 gtensor = fuse(gtensor, v1,
offset);
6563 htensor = fuse(htensor, v2,
offset);
6576 int gparticle= v1[0]==0 ? 0 : 1;
6577 int hparticle= v2[0]==0 ? 0 : 1;
6589 result_tmp.
get_svdtensor().set_vectors_and_weights(
w,tmp2,htensor_other);
6590 if (key.
level() > 0) {
6603 result_coeff1.
get_svdtensor().set_vectors_and_weights(
w,tmp2,htensor_other);
6606 result_coeff+=result_tmp;
6616 int hparticle= v2[0]==0 ? 0 : 1;
6629 int gparticle= v1[0]==0 ? 0 : 1;
6662 return c.trace_conj(fc);
6675 T new_inner, result = 0.0;
6682 if (old_inner ==
T(0)) {
6686 if (
coeffs.
find(key).get()->second.has_children()) {
6692 const keyT& child = it.key();
6696 new_inner = inner_child.
sum();
6697 }
else if (leaf_refine) {
6714 const keyT& child = it.key();
6718 new_inner = inner_child.
sum();
6722 new_inner = old_inner;
6734 const keyT& child = it.key();
6744 const std::shared_ptr< FunctionFunctorInterface<T, NDIM> >
fref;
6750 const implT * impl,
const bool leaf_refine,
const bool do_leaves)
6751 : fref(
f), impl(impl), leaf_refine(leaf_refine), do_leaves(do_leaves) {};
6754 if (do_leaves and it->second.is_leaf()) {
6755 tensorT cc = it->second.coeff().full_tensor();
6757 }
else if ((not do_leaves) and (it->first.level() == impl->
initial_level)) {
6758 tensorT cc = it->second.coeff().full_tensor();
6769 template <
typename Archive>
void serialize(
const Archive& ar) {
6805 const bool leaf_refine,
T old_inner=
T(0))
const {
6822 const keyT& child = it.key();
6829 if (leaf_refine and (
std::abs(new_inner - old_inner) > tol)) {
6831 const keyT& child = it.key();
6855 template <
typename L>
6879 template <
typename L>
6888 if (not below_leaf) {
6889 bool left_leaf = left->
coeffs.
find(key).get()->second.is_leaf();
6895 const keyT& child = it.key();
6905 if (lc.
size() == 0) {
6908 if (it->second.has_coeff())
6909 lc = it->second.coeff().reconstruct_tensor();
6913 if (
c.size() == 0) {
6934 const keyT& child = it.key();
6946 double dnorm =
d.normf();
6957 const keyT& child = it.key();
6961 child, left, left_coeff, child_coeff,
f,
alpha,
beta, tol, below_leaf);
6966 template <
typename L>
6982 template<
size_t LDIM>
6984 const int dim,
const bool fence) {
6999 coeff_op, apply_op,
cdata.key0);
7008 template<
size_t LDIM>
7015 typedef std::pair<bool,coeffT>
argT;
7057 const int k=fcoeff.
dim(0);
7058 const int k_ldim=std::pow(
k,LDIM);
7059 std::vector<long> shape(LDIM,
k);
7065 final=
inner(gtensor,ftensor,0,
dim).reshape(shape);
7068 if (fcoeff.
rank()>0) {
7071 const int otherdim = (
dim + 1) % 2;
7075 const tensorT gatensor =
inner(gtensor, atensor, 0, 1);
7080 for (
int r = 0; r < fcoeff.
rank(); ++r)
final +=
weights(r) * btensor(r,
_);
7081 final =
final.reshape(shape);
7111 return this_type(fimpl1,result1,iag1,dim1);
7114 template <
typename Archive>
void serialize(
const Archive& ar) {
7128 template<
size_t LDIM>
7131 typedef std::pair< keyT,coeffT > pairT;
7136 fiterator end =
f->get_coeffs().end();
7137 for (fiterator it=
f->get_coeffs().begin(); it!=end; ++it) {
7154 woT::task(
world.
rank(),&implT:: template do_project_out<LDIM>,fcoeff,result,key1,key2,dim);
7156 }
else if (dim==1) {
7164 woT::task(
world.
rank(),&implT:: template do_project_out<LDIM>,fcoeff,result,key2,key1,dim);
7186 template<
size_t LDIM>
7188 const Key<NDIM>& dest,
const int dim)
const {
7201 const int otherdim=(dim+1)%2;
7202 const int k=fcoeff.
dim(0);
7203 std::vector<Slice> s(fcoeff.
config().dim_per_vector()+1,
_);
7206 for (
int r=0; r<fcoeff.
rank(); ++r) {
7208 const tensorT contracted_tensor=fcoeff.
config().ref_vector(dim)(s).reshape(
k,
k,
k);
7209 const tensorT other_tensor=fcoeff.
config().ref_vector(otherdim)(s).reshape(
k,
k,
k);
7210 const double ovlp= gtensor.trace_conj(contracted_tensor);
7211 const double fac=ovlp * fcoeff.
config().weights(r);
7212 result+=fac*other_tensor;
7242 std::size_t
size()
const;
7248 std::size_t
nCoeff()
const;
7263 template <
typename Q,
typename F>
7267 typename fdcT::const_iterator end =
f.coeffs.
end();
7268 for (
typename fdcT::const_iterator it=
f.coeffs.begin(); it!=end; ++it) {
7269 const keyT& key = it->first;
7270 const fnodeT& node = it->second;
7272 if (node.has_coeff()) {
7303 template <
class Archive,
class T, std::
size_t NDIM>
7315 MADNESS_EXCEPTION(
"FunctionImpl: remote operation attempting to use a locally uninitialized object",0);
7318 MADNESS_EXCEPTION(
"FunctionImpl: remote operation attempting to use an unregistered object",0);
7325 template <
class Archive,
class T, std::
size_t NDIM>
7328 bool exists=(ptr) ?
true :
false;
7330 if (exists) ar & ptr->
id();
7334 template <
class Archive,
class T, std::
size_t NDIM>
7346 MADNESS_EXCEPTION(
"FunctionImpl: remote operation attempting to use a locally uninitialized object",0);
7351 MADNESS_EXCEPTION(
"FunctionImpl: remote operation attempting to use an unregistered object",0);
7359 template <
class Archive,
class T, std::
size_t NDIM>
7362 bool exists=(ptr) ?
true :
false;
7364 if (exists) ar & ptr->
id();
7369 template <
class Archive,
class T, std::
size_t NDIM>
7378 template <
class Archive,
class T, std::
size_t NDIM>
7385 template <
class Archive,
class T, std::
size_t NDIM>
7394 template <
class Archive,
class T, std::
size_t NDIM>
double w(double t, double eps)
Definition DKops.h:22
double q(double t)
Definition DKops.h:18
This header should include pretty much everything needed for the parallel runtime.
An integer with atomic set, get, read+increment, read+decrement, and decrement+test operations.
Definition atomicint.h:126
long dim(int i) const
Returns the size of dimension i.
Definition basetensor.h:147
long ndim() const
Returns the number of dimensions in the tensor.
Definition basetensor.h:144
long size() const
Returns the number of elements in the tensor.
Definition basetensor.h:138
Definition displacements.h:332
std::function< bool(Level, const PointPattern &, std::optional< Displacement > &)> Validator
Definition displacements.h:340
Definition displacements.h:784
a class to track where relevant (parent) coeffs are
Definition funcimpl.h:791
const keyT & key() const
const reference to the key
Definition funcimpl.h:839
CoeffTracker(const CoeffTracker &other, const datumT &datum)
ctor with a pair<keyT,nodeT>
Definition funcimpl.h:821
const LeafStatus & is_leaf() const
const reference to is_leaf flag
Definition funcimpl.h:863
const implT * impl
the funcimpl that has the coeffs
Definition funcimpl.h:800
LeafStatus
Definition funcimpl.h:797
@ yes
Definition funcimpl.h:797
@ no
Definition funcimpl.h:797
@ unknown
Definition funcimpl.h:797
CoeffTracker(const CoeffTracker &other)
copy ctor
Definition funcimpl.h:829
double dnorm(const keyT &key) const
return the s and dnorm belonging to the passed-in key
Definition funcimpl.h:856
coeffT coeff_
the coefficients belonging to key
Definition funcimpl.h:806
const implT * get_impl() const
const reference to impl
Definition funcimpl.h:833
const coeffT & coeff() const
const reference to the coeffs
Definition funcimpl.h:836
keyT key_
the current key, which must exists in impl
Definition funcimpl.h:802
double dnorm_
norm of d coefficients corresponding to key
Definition funcimpl.h:808
CoeffTracker(const implT *impl)
the initial ctor making the root key
Definition funcimpl.h:816
void serialize(const Archive &ar)
serialization
Definition funcimpl.h:915
Future< CoeffTracker > activate() const
find the coefficients
Definition funcimpl.h:892
CoeffTracker()
default ctor
Definition funcimpl.h:813
GenTensor< T > coeffT
Definition funcimpl.h:795
CoeffTracker make_child(const keyT &child) const
make a child of this, ignoring the coeffs
Definition funcimpl.h:866
FunctionImpl< T, NDIM > implT
Definition funcimpl.h:793
std::pair< Key< NDIM >, ShallowNode< T, NDIM > > datumT
Definition funcimpl.h:796
CoeffTracker forward_ctor(const CoeffTracker &other, const datumT &datum) const
taskq-compatible forwarding to the ctor
Definition funcimpl.h:909
LeafStatus is_leaf_
flag if key is a leaf node
Definition funcimpl.h:804
coeffT coeff(const keyT &key) const
return the coefficients belonging to the passed-in key
Definition funcimpl.h:847
Key< NDIM > keyT
Definition funcimpl.h:794
CompositeFunctorInterface implements a wrapper of holding several functions and functors.
Definition function_interface.h:172
Definition worldhashmap.h:396
Tri-diagonal operator traversing tree primarily for derivative operator.
Definition derivative.h:73
Holds displacements for applying operators to avoid replicating for all operators.
Definition displacements.h:65
const std::vector< Key< NDIM > > & get_disp(Level n, const array_of_bools< NDIM > &kernel_lattice_sum_axes)
Definition displacements.h:236
FunctionCommonData holds all Function data common for given k.
Definition function_common_data.h:52
Tensor< double > quad_phit
transpose of quad_phi
Definition function_common_data.h:102
Tensor< double > quad_phiw
quad_phiw(i,j) = at x[i] value of w[i]*phi[j]
Definition function_common_data.h:103
std::vector< long > vk
(k,...) used to initialize Tensors
Definition function_common_data.h:93
std::vector< Slice > s0
s[0] in each dimension to get scaling coeff
Definition function_common_data.h:91
static const FunctionCommonData< T, NDIM > & get(int k)
Definition function_common_data.h:111
static void _init_quadrature(int k, int npt, Tensor< double > &quad_x, Tensor< double > &quad_w, Tensor< double > &quad_phi, Tensor< double > &quad_phiw, Tensor< double > &quad_phit)
Initialize the quadrature information.
Definition mraimpl.h:91
collect common functionality does not need to be member function of funcimpl
Definition function_common_data.h:135
const FunctionCommonData< T, NDIM > & cdata
Definition function_common_data.h:138
GenTensor< T > coeffs2values(const Key< NDIM > &key, const GenTensor< T > &coeff) const
Definition function_common_data.h:142
Tensor< T > values2coeffs(const Key< NDIM > &key, const Tensor< T > &values) const
Definition function_common_data.h:155
FunctionDefaults holds default paramaters as static class members.
Definition funcdefaults.h:100
static const double & get_thresh()
Returns the default threshold.
Definition funcdefaults.h:177
static int get_max_refine_level()
Gets the default maximum adaptive refinement level.
Definition funcdefaults.h:214
static const Tensor< double > & get_cell_width()
Returns the width of each user cell dimension.
Definition funcdefaults.h:381
static bool get_apply_randomize()
Gets the random load balancing for integral operators flag.
Definition funcdefaults.h:290
static const Tensor< double > & get_cell()
Gets the user cell for the simulation.
Definition funcdefaults.h:348
FunctionFactory implements the named-parameter idiom for Function.
Definition function_factory.h:86
bool _refine
Definition function_factory.h:99
bool _empty
Definition function_factory.h:100
bool _fence
Definition function_factory.h:103
Abstract base class interface required for functors used as input to Functions.
Definition function_interface.h:68
Definition funcimpl.h:5542
double operator()(double a, double b) const
Definition funcimpl.h:5568
const opT * func
Definition funcimpl.h:5544
Tensor< double > qx
Definition funcimpl.h:5546
double operator()(typename dcT::const_iterator &it) const
Definition funcimpl.h:5559
void serialize(const Archive &ar)
Definition funcimpl.h:5573
do_err_box(const implT *impl, const opT *func, int npt, const Tensor< double > &qx, const Tensor< double > &quad_phit, const Tensor< double > &quad_phiw)
Definition funcimpl.h:5552
int npt
Definition funcimpl.h:5545
Tensor< double > quad_phiw
Definition funcimpl.h:5548
const implT * impl
Definition funcimpl.h:5543
Tensor< double > quad_phit
Definition funcimpl.h:5547
do_err_box(const do_err_box &e)
Definition funcimpl.h:5556
FunctionImpl holds all Function state to facilitate shallow copy semantics.
Definition funcimpl.h:945
std::tuple< std::set< Key< NDIM > >, std::map< Key< CDIM >, double > > get_contraction_node_lists(const std::size_t n, const std::array< int, CDIM > &v) const
for contraction two functions f(x,z) = \int g(x,y) h(y,z) dy
Definition funcimpl.h:6309
void copy_coeffs(const FunctionImpl< Q, NDIM > &other, bool fence)
Copy coeffs from other into self.
Definition funcimpl.h:1145
bool is_nonstandard() const
Definition mraimpl.h:273
void insert_serialized_coeffs(std::vector< unsigned char > &v)
insert coeffs from vector archive into this
Definition funcimpl.h:1191
T eval_cube(Level n, coordT &x, const tensorT &c) const
Definition mraimpl.h:2025
void partial_inner_contract(const FunctionImpl< Q, LDIM > *g, const FunctionImpl< R, KDIM > *h, const std::array< int, CDIM > v1, const std::array< int, CDIM > v2, const Key< NDIM > &key, const std::list< Key< CDIM > > &j_key_list)
tensor contraction part of partial_inner
Definition funcimpl.h:6471
AtomicInt large
Definition funcimpl.h:1002
Timer timer_target_driven
Definition funcimpl.h:1000
void binaryXX(const FunctionImpl< L, NDIM > *left, const FunctionImpl< R, NDIM > *right, const opT &op, bool fence)
Definition funcimpl.h:3275
void do_apply(const opT *op, const keyT &key, const Tensor< R > &c)
apply an operator on the coeffs c (at node key)
Definition funcimpl.h:4882
void do_print_tree_graphviz(const keyT &key, std::ostream &os, Level maxlevel) const
Functor for the do_print_tree method (using GraphViz)
Definition mraimpl.h:2763
void add_keys_to_map(mapT *map, int index) const
Adds keys to union of local keys with specified index.
Definition funcimpl.h:5886
void change_tensor_type1(const TensorArgs &targs, bool fence)
change the tensor type of the coefficients in the FunctionNode
Definition mraimpl.h:1099
void gaxpy_ext_recursive(const keyT &key, const FunctionImpl< L, NDIM > *left, Tensor< L > lcin, tensorT c, T(*f)(const coordT &), T alpha, T beta, double tol, bool below_leaf)
Definition funcimpl.h:6880
int initial_level
Initial level for refinement.
Definition funcimpl.h:974
int max_refine_level
Do not refine below this level.
Definition funcimpl.h:978
double do_apply_kernel3(const opT *op, const GenTensor< R > &coeff, const do_op_args< OPDIM > &args, const TensorArgs &apply_targs)
same as do_apply_kernel2, but use low rank tensors as input and low rank tensors as output
Definition funcimpl.h:4840
void hartree_product(const std::vector< std::shared_ptr< FunctionImpl< T, LDIM > > > p1, const std::vector< std::shared_ptr< FunctionImpl< T, LDIM > > > p2, const leaf_opT &leaf_op, bool fence)
given two functions of LDIM, perform the Hartree/Kronecker/outer product
Definition funcimpl.h:3799
void traverse_tree(const coeff_opT &coeff_op, const apply_opT &apply_op, const keyT &key) const
traverse a non-existing tree
Definition funcimpl.h:3769
void do_square_inplace(const keyT &key)
int special_level
Minimium level for refinement on special points.
Definition funcimpl.h:975
void do_apply_kernel(const opT *op, const Tensor< R > &c, const do_op_args< OPDIM > &args)
for fine-grain parallelism: call the apply method of an operator in a separate task
Definition funcimpl.h:4774
double errsq_local(const opT &func) const
Returns the sum of squares of errors from local info ... no comms.
Definition funcimpl.h:5580
WorldContainer< keyT, nodeT > dcT
Type of container holding the coefficients.
Definition funcimpl.h:957
void evaldepthpt(const Vector< double, NDIM > &xin, const keyT &keyin, const typename Future< Level >::remote_refT &ref)
Get the depth of the tree at a point in simulation coordinates.
Definition mraimpl.h:2944
void scale_inplace(const T q, bool fence)
In-place scale by a constant.
Definition mraimpl.h:3115
void gaxpy_oop_reconstructed(const double alpha, const implT &f, const double beta, const implT &g, const bool fence)
perform: this= alpha*f + beta*g, invoked by result
Definition mraimpl.h:223
void unary_op_coeff_inplace(const opT &op, bool fence)
Definition funcimpl.h:2119
World & world
Definition funcimpl.h:964
void apply_1d_realspace_push_op(const archive::archive_ptr< const opT > &pop, int axis, const keyT &key, const Tensor< R > &c)
Definition funcimpl.h:3837
bool is_redundant() const
Returns true if the function is redundant.
Definition mraimpl.h:262
FunctionNode< T, NDIM > nodeT
Type of node.
Definition funcimpl.h:955
std::size_t nCoeff_local() const
Returns the number of coefficients in the function for this MPI rank.
Definition mraimpl.h:1922
void print_size(const std::string name) const
print tree size and size
Definition mraimpl.h:1941
FunctionImpl(const FunctionImpl< T, NDIM > &p)
void print_info() const
Prints summary of data distribution.
Definition mraimpl.h:833
void abs_inplace(bool fence)
Definition mraimpl.h:3127
void binaryXXa(const keyT &key, const FunctionImpl< L, NDIM > *left, const Tensor< L > &lcin, const FunctionImpl< R, NDIM > *right, const Tensor< R > &rcin, const opT &op)
Definition funcimpl.h:3144
void print_timer() const
Definition mraimpl.h:357
void evalR(const Vector< double, NDIM > &xin, const keyT &keyin, const typename Future< long >::remote_refT &ref)
Get the rank of leaf box of the tree at a point in simulation coordinates.
Definition mraimpl.h:2986
const FunctionCommonData< T, NDIM > & cdata
Definition funcimpl.h:984
void do_print_grid(const std::string filename, const std::vector< keyT > &keys) const
print the grid in xyz format
Definition mraimpl.h:584
void mulXXa(const keyT &key, const FunctionImpl< L, NDIM > *left, const Tensor< L > &lcin, const FunctionImpl< R, NDIM > *right, const Tensor< R > &rcin, double tol)
Definition funcimpl.h:3058
int get_truncate_mode() const
Definition funcimpl.h:1757
const std::vector< Vector< double, NDIM > > & get_special_points() const
Definition funcimpl.h:969
std::size_t nCoeff() const
Returns the number of coefficients in the function ... collective global sum.
Definition mraimpl.h:1932
double vol_nsphere(int n, double R)
Definition funcimpl.h:4870
keyT neighbor_in_volume(const keyT &key, const keyT &disp) const
Returns key of general neighbor that resides in-volume.
Definition mraimpl.h:3240
void compress(const TreeState newstate, bool fence)
compress the wave function
Definition mraimpl.h:1500
void do_dirac_convolution(FunctionImpl< T, LDIM > *f, bool fence) const
Definition funcimpl.h:2202
std::pair< coeffT, double > compress_op(const keyT &key, const std::vector< Future< std::pair< coeffT, double > > > &v, bool nonstandard)
calculate the wavelet coefficients using the sum coefficients of all child nodes
Definition mraimpl.h:1668
Future< bool > truncate_spawn(const keyT &key, double tol)
Returns true if after truncation this node has coefficients.
Definition mraimpl.h:2608
void print_type_in_compilation_error(R &&)
Definition funcimpl.h:6191
Future< double > norm_tree_spawn(const keyT &key)
Definition mraimpl.h:1570
std::vector< keyT > local_leaf_keys() const
return the keys of the local leaf boxes
Definition mraimpl.h:558
MADNESS_ASSERT(this->is_redundant()==g.is_redundant())
void do_print_tree(const keyT &key, std::ostream &os, Level maxlevel) const
Functor for the do_print_tree method.
Definition mraimpl.h:2681
void vtransform(const std::vector< std::shared_ptr< FunctionImpl< R, NDIM > > > &vright, const Tensor< Q > &c, const std::vector< std::shared_ptr< FunctionImpl< T, NDIM > > > &vleft, double tol, bool fence)
Definition funcimpl.h:2919
void unset_functor()
Definition mraimpl.h:312
void refine_spawn(const opT &op, const keyT &key)
Definition funcimpl.h:4602
void apply_1d_realspace_push(const opT &op, const FunctionImpl< R, NDIM > *f, int axis, bool fence)
Definition funcimpl.h:3888
void do_print_plane(const std::string filename, std::vector< Tensor< double > > plotinfo, const int xaxis, const int yaxis, const coordT el2)
print the MRA structure
Definition mraimpl.h:499
std::pair< Key< NDIM >, ShallowNode< T, NDIM > > find_datum(keyT key) const
return the a std::pair<key, node>, which MUST exist
Definition mraimpl.h:965
void set_functor(const std::shared_ptr< FunctionFunctorInterface< T, NDIM > > functor1)
Definition mraimpl.h:293
std::enable_if< NDIM==FDIM >::type read_grid2(const std::string gridfile, std::shared_ptr< FunctionFunctorInterface< double, NDIM > > vnuc_functor)
read data from a grid
Definition funcimpl.h:1651
bool verify_tree_state_local() const
check that the tree state and the coeffs are consistent
Definition mraimpl.h:169
const std::shared_ptr< WorldDCPmapInterface< Key< NDIM > > > & get_pmap() const
Definition mraimpl.h:207
Tensor< Q > fcube_for_mul(const keyT &child, const keyT &parent, const Tensor< Q > &coeff) const
Compute the function values for multiplication.
Definition funcimpl.h:1966
Timer timer_filter
Definition funcimpl.h:998
void sock_it_to_me(const keyT &key, const RemoteReference< FutureImpl< std::pair< keyT, coeffT > > > &ref) const
Walk up the tree returning pair(key,node) for first node with coefficients.
Definition mraimpl.h:2821
void recursive_apply(opT &apply_op, const implT *fimpl, implT *rimpl, const bool fence)
traverse an existing tree and apply an operator
Definition funcimpl.h:5399
double get_thresh() const
Definition mraimpl.h:328
void trickle_down(bool fence)
sum all the contributions from all scales after applying an operator in mod-NS form
Definition mraimpl.h:1354
bool autorefine
If true, autorefine where appropriate.
Definition funcimpl.h:980
std::pair< coeffT, double > make_redundant_op(const keyT &key, const std::vector< Future< std::pair< coeffT, double > > > &v)
similar to compress_op, but insert only the sum coefficients in the tree
Definition mraimpl.h:1728
void set_autorefine(bool value)
Definition mraimpl.h:337
tensorT filter(const tensorT &s) const
Transform sum coefficients at level n to sums+differences at level n-1.
Definition mraimpl.h:1152
void chop_at_level(const int n, const bool fence=true)
remove all nodes with level higher than n
Definition mraimpl.h:1115
void unaryXXvalues(const FunctionImpl< Q, NDIM > *func, const opT &op, bool fence)
Definition funcimpl.h:3302
void partial_inner(const FunctionImpl< Q, LDIM > &g, const FunctionImpl< R, KDIM > &h, const std::array< int, CDIM > v1, const std::array< int, CDIM > v2)
invoked by result
Definition funcimpl.h:6207
TreeState tree_state
Definition funcimpl.h:987
void print_tree_json(std::ostream &os=std::cout, Level maxlevel=10000) const
Definition mraimpl.h:2701
coeffT parent_to_child_NS(const keyT &child, const keyT &parent, const coeffT &coeff) const
Directly project parent NS coeffs to child NS coeffs.
Definition mraimpl.h:707
void copy_coeffs_different_world(const FunctionImpl< Q, NDIM > &other)
Copy coefficients from other funcimpl with possibly different world and on a different node.
Definition funcimpl.h:1155
void mapdim(const implT &f, const std::vector< long > &map, bool fence)
Permute the dimensions of f according to map, result on this.
Definition mraimpl.h:1057
bool is_compressed() const
Returns true if the function is compressed.
Definition mraimpl.h:250
Vector< double, NDIM > coordT
Type of vector holding coordinates.
Definition funcimpl.h:959
void apply(opT &op, const FunctionImpl< R, NDIM > &f, bool fence)
apply an operator on f to return this
Definition funcimpl.h:5082
Tensor< T > tensorT
Type of tensor for anything but to hold coeffs.
Definition funcimpl.h:952
void mirror(const implT &f, const std::vector< long > &mirror, bool fence)
mirror the dimensions of f according to map, result on this
Definition mraimpl.h:1066
T inner_adaptive_recursive(keyT key, const tensorT &c, const std::shared_ptr< FunctionFunctorInterface< T, NDIM > > f, const bool leaf_refine, T old_inner=T(0)) const
Definition funcimpl.h:6803
void store(Archive &ar)
Definition funcimpl.h:1323
void do_binary_op(const keyT &key, const Tensor< L > &left, const std::pair< keyT, Tensor< R > > &arg, const opT &op)
Functor for the binary_op method.
Definition funcimpl.h:2068
void gaxpy_ext(const FunctionImpl< L, NDIM > *left, T(*f)(const coordT &), T alpha, T beta, double tol, bool fence)
Definition funcimpl.h:6967
void accumulate_trees(FunctionImpl< Q, NDIM > &result, const R alpha, const bool fence=true) const
merge the trees of this and other, while multiplying them with the alpha or beta, resp
Definition funcimpl.h:1244
void print_stats() const
print the number of configurations per node
Definition mraimpl.h:1969
void broaden(const array_of_bools< NDIM > &is_periodic, bool fence)
Definition mraimpl.h:1303
coeffT truncate_reconstructed_op(const keyT &key, const std::vector< Future< coeffT > > &v, const double tol)
given the sum coefficients of all children, truncate or not
Definition mraimpl.h:1617
void refine_op(const opT &op, const keyT &key)
Definition funcimpl.h:4577
static Tensor< TENSOR_RESULT_TYPE(T, R) > inner_local(const std::vector< const FunctionImpl< T, NDIM > * > &left, const std::vector< const FunctionImpl< R, NDIM > * > &right, bool sym)
Definition funcimpl.h:6087
void fcube(const keyT &key, const FunctionFunctorInterface< T, NDIM > &f, const Tensor< double > &qx, tensorT &fval) const
Evaluate function at quadrature points in the specified box.
Definition mraimpl.h:2446
Timer timer_change_tensor_type
Definition funcimpl.h:996
void forward_do_diff1(const DerivativeBase< T, NDIM > *D, const implT *f, const keyT &key, const std::pair< keyT, coeffT > &left, const std::pair< keyT, coeffT > ¢er, const std::pair< keyT, coeffT > &right)
Definition mraimpl.h:923
std::vector< Slice > child_patch(const keyT &child) const
Returns patch referring to coeffs of child in parent box.
Definition mraimpl.h:696
void print_tree_graphviz(std::ostream &os=std::cout, Level maxlevel=10000) const
Definition mraimpl.h:2754
void set_tree_state(const TreeState &state)
Definition funcimpl.h:1354
std::size_t min_nodes() const
Returns the min number of nodes on a processor.
Definition mraimpl.h:1873
void copy_coeffs_same_world(const FunctionImpl< Q, NDIM > &other, bool fence)
Copy coeffs from other into self.
Definition funcimpl.h:1198
std::shared_ptr< FunctionFunctorInterface< T, NDIM > > functor
Definition funcimpl.h:986
Timer timer_compress_svd
Definition funcimpl.h:999
Tensor< TENSOR_RESULT_TYPE(T, R)> mul(const Tensor< T > &c1, const Tensor< R > &c2, const int npt, const keyT &key) const
multiply the values of two coefficient tensors using a custom number of grid points
Definition funcimpl.h:2041
void make_redundant(const bool fence)
convert this to redundant, i.e. have sum coefficients on all levels
Definition mraimpl.h:1528
void load(Archive &ar)
Definition funcimpl.h:1305
std::size_t max_nodes() const
Returns the max number of nodes on a processor.
Definition mraimpl.h:1864
T inner_ext_local(const std::shared_ptr< FunctionFunctorInterface< T, NDIM > > f, const bool leaf_refine) const
Definition funcimpl.h:6778
coeffT upsample(const keyT &key, const coeffT &coeff) const
upsample the sum coefficients of level 1 to sum coeffs on level n+1
Definition mraimpl.h:1231
TensorArgs targs
type of tensor to be used in the FunctionNodes
Definition funcimpl.h:982
void flo_unary_op_node_inplace(const opT &op, bool fence)
Definition funcimpl.h:2231
std::size_t size_local() const
Returns the number of coefficients in the function for each rank.
Definition mraimpl.h:1891
GenTensor< Q > values2coeffs(const keyT &key, const GenTensor< Q > &values) const
Definition funcimpl.h:1945
void plot_cube_kernel(archive::archive_ptr< Tensor< T > > ptr, const keyT &key, const coordT &plotlo, const coordT &plothi, const std::vector< long > &npt, bool eval_refine) const
Definition mraimpl.h:3331
T trace_local() const
Returns int(f(x),x) in local volume.
Definition mraimpl.h:3169
void print_grid(const std::string filename) const
Definition mraimpl.h:542
Future< std::pair< coeffT, double > > compress_spawn(const keyT &key, bool nonstandard, bool keepleaves, bool redundant1)
Invoked on node where key is local.
Definition mraimpl.h:3268
void replicate_on_hosts(bool fence=true)
Definition funcimpl.h:1124
bool get_autorefine() const
Definition mraimpl.h:334
int k
Wavelet order.
Definition funcimpl.h:972
void vtransform_doit(const std::shared_ptr< FunctionImpl< R, NDIM > > &right, const Tensor< Q > &c, const std::vector< std::shared_ptr< FunctionImpl< T, NDIM > > > &vleft, double tol)
Definition funcimpl.h:2763
MADNESS_CHECK(this->is_reconstructed())
void phi_for_mul(Level np, Translation lp, Level nc, Translation lc, Tensor< double > &phi) const
Compute the Legendre scaling functions for multiplication.
Definition mraimpl.h:3137
Future< std::pair< keyT, coeffT > > find_me(const keyT &key) const
find_me. Called by diff_bdry to get coefficients of boundary function
Definition mraimpl.h:3255
TensorType get_tensor_type() const
Definition mraimpl.h:319
void do_project_out(const coeffT &fcoeff, const std::pair< keyT, coeffT > gpair, const keyT &gkey, const Key< NDIM > &dest, const int dim) const
compute the inner product of two nodes of only some dimensions and accumulate on result
Definition funcimpl.h:7187
void remove_leaf_coefficients(const bool fence)
Definition mraimpl.h:1522
void insert_zero_down_to_initial_level(const keyT &key)
Initialize nodes to zero function at initial_level of refinement.
Definition mraimpl.h:2577
void do_diff1(const DerivativeBase< T, NDIM > *D, const implT *f, const keyT &key, const std::pair< keyT, coeffT > &left, const std::pair< keyT, coeffT > ¢er, const std::pair< keyT, coeffT > &right)
Definition mraimpl.h:934
typedef TENSOR_RESULT_TYPE(T, R) resultT
void unary_op_node_inplace(const opT &op, bool fence)
Definition funcimpl.h:2140
T inner_adaptive_local(const std::shared_ptr< FunctionFunctorInterface< T, NDIM > > f, const bool leaf_refine) const
Definition funcimpl.h:6789
void do_print_tree_json(const keyT &key, std::multimap< Level, std::tuple< tranT, std::string > > &data, Level maxlevel) const
Functor for the do_print_tree_json method.
Definition mraimpl.h:2732
std::multimap< Key< FDIM >, std::list< Key< CDIM > > > recur_down_for_contraction_map(const keyT &key, const nodeT &node, const std::array< int, CDIM > &v_this, const std::array< int, CDIM > &v_other, const std::set< Key< ODIM > > &ij_other_list, const std::map< Key< CDIM >, double > &j_other_list, bool this_first, const double thresh)
make a map of all nodes that will contribute to a partial inner product
Definition funcimpl.h:6362
std::shared_ptr< FunctionImpl< T, NDIM > > pimplT
pointer to this class
Definition funcimpl.h:951
TENSOR_RESULT_TYPE(T, R) dot_local(const FunctionImpl< R
Returns the dot product ASSUMING same distribution.
void finalize_sum()
after summing up we need to do some cleanup;
Definition mraimpl.h:1821
std::enable_if< NDIM==FDIM >::type read_grid(const std::string keyfile, const std::string gridfile, std::shared_ptr< FunctionFunctorInterface< double, NDIM > > vnuc_functor)
read data from a grid
Definition funcimpl.h:1544
dcT coeffs
The coefficients.
Definition funcimpl.h:989
bool exists_and_is_leaf(const keyT &key) const
Definition mraimpl.h:1275
static std::complex< Real > conj(const std::complex< Real > &x)
Definition funcimpl.h:6081
void make_Vphi(const opT &leaf_op, const bool fence=true)
assemble the function V*phi using V and phi given from the functor
Definition funcimpl.h:4369
void unaryXX(const FunctionImpl< Q, NDIM > *func, const opT &op, bool fence)
Definition funcimpl.h:3289
std::vector< std::pair< int, const coeffT * > > mapvecT
Type of the entry in the map returned by make_key_vec_map.
Definition funcimpl.h:5880
void project_out(FunctionImpl< T, NDIM-LDIM > *result, const FunctionImpl< T, LDIM > *gimpl, const int dim, const bool fence)
project the low-dim function g on the hi-dim function f: result(x) = <this(x,y) | g(y)>
Definition funcimpl.h:6983
void verify_tree() const
Verify tree is properly constructed ... global synchronization involved.
Definition mraimpl.h:111
void do_square_inplace2(const keyT &parent, const keyT &child, const tensorT &parent_coeff)
void gaxpy_inplace_reconstructed(const T &alpha, const FunctionImpl< Q, NDIM > &g, const R &beta, const bool fence)
Definition funcimpl.h:1212
void undo_replicate(bool fence=true)
Definition funcimpl.h:1129
void set_tensor_args(const TensorArgs &t)
Definition mraimpl.h:325
GenTensor< Q > fcube_for_mul(const keyT &child, const keyT &parent, const GenTensor< Q > &coeff) const
Compute the function values for multiplication.
Definition funcimpl.h:1994
Range< typename dcT::const_iterator > rangeT
Definition funcimpl.h:5671
std::size_t real_size() const
Returns the number of coefficients in the function ... collective global sum.
Definition mraimpl.h:1909
bool exists_and_has_children(const keyT &key) const
Definition mraimpl.h:1270
void sum_down_spawn(const keyT &key, const coeffT &s)
is this the same as trickle_down() ?
Definition mraimpl.h:876
void multi_to_multi_op_values(const opT &op, const std::vector< implT * > &vin, std::vector< implT * > &vout, const bool fence=true)
Inplace operate on many functions (impl's) with an operator within a certain box.
Definition funcimpl.h:2890
long box_interior[1000]
Definition funcimpl.h:3333
keyT neighbor(const keyT &key, const keyT &disp, const array_of_bools< NDIM > &is_periodic) const
Returns key of general neighbor enforcing BC.
Definition mraimpl.h:3225
GenTensor< Q > NS_fcube_for_mul(const keyT &child, const keyT &parent, const GenTensor< Q > &coeff, const bool s_only) const
Compute the function values for multiplication.
Definition funcimpl.h:1864
rangeT range(coeffs.begin(), coeffs.end())
void norm_tree(bool fence)
compute for each FunctionNode the norm of the function inside that node
Definition mraimpl.h:1547
void gaxpy_inplace(const T &alpha, const FunctionImpl< Q, NDIM > &other, const R &beta, bool fence)
Inplace general bilinear operation.
Definition funcimpl.h:1292
const Tensor< double > cell
the size of the root cell in each dimension, unchangeable
Definition funcimpl.h:977
bool has_leaves() const
Definition mraimpl.h:288
bool verify_parents_and_children() const
check that parents and children are consistent
Definition mraimpl.h:119
void apply_source_driven(opT &op, const FunctionImpl< R, NDIM > &f, bool fence)
similar to apply, but for low rank coeffs
Definition funcimpl.h:5224
void distribute(std::shared_ptr< WorldDCPmapInterface< Key< NDIM > > > newmap) const
Definition funcimpl.h:1136
int get_special_level() const
Definition funcimpl.h:968
void reconstruct_op(const keyT &key, const coeffT &s, const bool accumulate_NS=true)
Definition mraimpl.h:2079
tensorT gaxpy_ext_node(keyT key, Tensor< L > lc, T(*f)(const coordT &), T alpha, T beta) const
Definition funcimpl.h:6856
const coeffT parent_to_child(const coeffT &s, const keyT &parent, const keyT &child) const
Directly project parent coeffs to child coeffs.
Definition mraimpl.h:3152
WorldObject< FunctionImpl< T, NDIM > > woT
Base class world object type.
Definition funcimpl.h:947
void undo_redundant(const bool fence)
convert this from redundant to standard reconstructed form
Definition mraimpl.h:1538
GenTensor< T > coeffT
Type of tensor used to hold coeffs.
Definition funcimpl.h:956
const keyT & key0() const
Returns cdata.key0.
Definition mraimpl.h:394
double finalize_apply()
after apply we need to do some cleanup;
Definition mraimpl.h:1778
bool leaves_only
Definition funcimpl.h:5676
friend hashT hash_value(const FunctionImpl< T, NDIM > *pimpl)
Hash a pointer to FunctionImpl.
Definition funcimpl.h:7287
const dcT & get_coeffs() const
Definition mraimpl.h:343
FunctionImpl(World &world, const FunctionImpl< Q, NDIM > &other, const std::shared_ptr< WorldDCPmapInterface< Key< NDIM > > > &pmap, bool dozero)
Copy constructor.
Definition funcimpl.h:1085
T inner_ext_node(keyT key, tensorT c, const std::shared_ptr< FunctionFunctorInterface< T, NDIM > > f) const
Return the inner product with an external function on a specified function node.
Definition funcimpl.h:6655
double norm2sq_local() const
Returns the square of the local norm ... no comms.
Definition mraimpl.h:1830
const FunctionCommonData< T, NDIM > & get_cdata() const
Definition mraimpl.h:349
void sum_down(bool fence)
After 1d push operator must sum coeffs down the tree to restore correct scaling function coefficients...
Definition mraimpl.h:915
T inner_ext_recursive(keyT key, tensorT c, const std::shared_ptr< FunctionFunctorInterface< T, NDIM > > f, const bool leaf_refine, T old_inner=T(0)) const
Definition funcimpl.h:6672
bool noautorefine(const keyT &key, const tensorT &t) const
Always returns false (for when autorefine is not wanted)
Definition mraimpl.h:859
double truncate_tol(double tol, const keyT &key) const
Returns the truncation threshold according to truncate_method.
Definition mraimpl.h:649
void flo_unary_op_node_inplace(const opT &op, bool fence) const
Definition funcimpl.h:2241
bool autorefine_square_test(const keyT &key, const nodeT &t) const
Returns true if this block of coeffs needs autorefining.
Definition mraimpl.h:865
void erase(const Level &max_level)
truncate tree at a certain level
Definition mraimpl.h:739
void mulXX(const FunctionImpl< L, NDIM > *left, const FunctionImpl< R, NDIM > *right, double tol, bool fence)
Definition funcimpl.h:3261
void reconstruct(bool fence)
reconstruct this tree – respects fence
Definition mraimpl.h:1468
void multiply(const implT *f, const FunctionImpl< T, LDIM > *g, const int particle)
multiply f (a pair function of NDIM) with an orbital g (LDIM=NDIM/2)
Definition funcimpl.h:3661
coeffT assemble_coefficients(const keyT &key, const coeffT &coeff_ket, const coeffT &vpotential1, const coeffT &vpotential2, const tensorT &veri) const
given several coefficient tensors, assemble a result tensor
Definition mraimpl.h:1013
static void tnorm(const tensorT &t, double *lo, double *hi)
Computes norm of low/high-order polyn. coeffs for autorefinement test.
Definition mraimpl.h:3029
std::pair< bool, T > eval_local_only(const Vector< double, NDIM > &xin, Level maxlevel)
Evaluate function only if point is local returning (true,value); otherwise return (false,...
Definition mraimpl.h:2915
std::size_t max_depth() const
Returns the maximum depth of the tree ... collective ... global sum/broadcast.
Definition mraimpl.h:1856
std::size_t size() const
Returns the number of coefficients in the function ... collective global sum.
Definition mraimpl.h:1901
void reduce_rank(const double thresh, bool fence)
reduce the rank of the coefficients tensors
Definition mraimpl.h:1107
TreeState get_tree_state() const
Definition funcimpl.h:1358
void merge_trees(const T alpha, const FunctionImpl< Q, NDIM > &other, const R beta, const bool fence=true)
merge the trees of this and other, while multiplying them with the alpha or beta, resp
Definition funcimpl.h:1232
const Tensor< double > & get_cell() const
return the simulation cell
Definition funcimpl.h:1377
std::shared_ptr< FunctionFunctorInterface< T, NDIM > > get_functor()
Definition mraimpl.h:300
double do_apply_directed_screening(const opT *op, const keyT &key, const coeffT &coeff, const bool &do_kernel)
apply an operator on the coeffs c (at node key)
Definition funcimpl.h:5115
tensorT unfilter(const tensorT &s) const
Transform sums+differences at level n to sum coefficients at level n+1.
Definition mraimpl.h:1181
int get_initial_level() const
getter
Definition funcimpl.h:967
Tensor< T > eval_plot_cube(const coordT &plotlo, const coordT &plothi, const std::vector< long > &npt, const bool eval_refine=false) const
Definition mraimpl.h:3423
virtual ~FunctionImpl()
Definition funcimpl.h:1116
Vector< Translation, NDIM > tranT
Type of array holding translation.
Definition funcimpl.h:953
void change_tree_state(const TreeState finalstate, bool fence=true)
change the tree state of this function, might or might not respect fence!
Definition mraimpl.h:1407
Future< coeffT > truncate_reconstructed_spawn(const keyT &key, const double tol)
truncate using a tree in reconstructed form
Definition mraimpl.h:1593
GenTensor< Q > coeffs2values(const keyT &key, const GenTensor< Q > &coeff) const
Definition funcimpl.h:1812
FunctionImpl(const FunctionFactory< T, NDIM > &factory)
Initialize function impl from data in factory.
Definition funcimpl.h:1005
void map_and_mirror(const implT &f, const std::vector< long > &map, const std::vector< long > &mirror, bool fence)
map and mirror the translation index and the coefficients, result on this
Definition mraimpl.h:1076
Timer timer_lr_result
Definition funcimpl.h:997
void gaxpy(T alpha, const FunctionImpl< L, NDIM > &left, T beta, const FunctionImpl< R, NDIM > &right, bool fence)
Invoked by result to perform result += alpha*left+beta*right in wavelet basis.
Definition funcimpl.h:2091
void truncate(double tol, bool fence)
Truncate according to the threshold with optional global fence.
Definition mraimpl.h:378
void do_mul(const keyT &key, const Tensor< L > &left, const std::pair< keyT, Tensor< R > > &arg)
Functor for the mul method.
Definition funcimpl.h:2016
void copy_remote_coeffs_from_pid(const ProcessID pid, const FunctionImpl< Q, NDIM > &other)
Definition funcimpl.h:1175
void project_out2(const FunctionImpl< T, LDIM+NDIM > *f, const FunctionImpl< T, LDIM > *g, const int dim)
project the low-dim function g on the hi-dim function f: this(x) = <f(x,y) | g(y)>
Definition funcimpl.h:7129
double do_apply_kernel2(const opT *op, const Tensor< R > &c, const do_op_args< OPDIM > &args, const TensorArgs &apply_targs)
same as do_apply_kernel, but use full rank tensors as input and low rank tensors as output
Definition funcimpl.h:4802
static Tensor< TENSOR_RESULT_TYPE(T, R)> dot_local(const std::vector< const FunctionImpl< T, NDIM > * > &left, const std::vector< const FunctionImpl< R, NDIM > * > &right, bool sym)
Definition funcimpl.h:6139
Tensor< Q > coeffs2values(const keyT &key, const Tensor< Q > &coeff) const
Definition funcimpl.h:1938
Tensor< Q > values2coeffs(const keyT &key, const Tensor< Q > &values) const
Definition funcimpl.h:1952
void multi_to_multi_op_values_doit(const keyT &key, const opT &op, const std::vector< implT * > &vin, std::vector< implT * > &vout)
Inplace operate on many functions (impl's) with an operator within a certain box.
Definition funcimpl.h:2867
bool is_reconstructed() const
Returns true if the function is compressed.
Definition mraimpl.h:256
void replicate(bool fence=true)
Definition funcimpl.h:1120
double norm_tree_op(const keyT &key, const std::vector< Future< double > > &v)
Definition mraimpl.h:1555
void reset_timer()
Definition mraimpl.h:366
void refine_to_common_level(const std::vector< FunctionImpl< T, NDIM > * > &v, const std::vector< tensorT > &c, const keyT key)
Refine multiple functions down to the same finest level.
Definition mraimpl.h:769
int get_k() const
Definition mraimpl.h:340
void dirac_convolution_op(const keyT &key, const nodeT &node, FunctionImpl< T, LDIM > *f) const
The operator.
Definition funcimpl.h:2157
FunctionImpl< T, NDIM > implT
Type of this class (implementation)
Definition funcimpl.h:950
void eval(const Vector< double, NDIM > &xin, const keyT &keyin, const typename Future< T >::remote_refT &ref)
Evaluate the function at a point in simulation coordinates.
Definition mraimpl.h:2871
bool truncate_op(const keyT &key, double tol, const std::vector< Future< bool > > &v)
Definition mraimpl.h:2644
void zero_norm_tree()
Definition mraimpl.h:1292
std::size_t max_local_depth() const
Returns the maximum local depth of the tree ... no communications.
Definition mraimpl.h:1842
tensorT project(const keyT &key) const
Definition mraimpl.h:2789
double thresh
Screening threshold.
Definition funcimpl.h:973
double check_symmetry_local() const
Returns some asymmetry measure ... no comms.
Definition mraimpl.h:755
Future< double > get_norm_tree_recursive(const keyT &key) const
Definition mraimpl.h:2810
bool is_redundant_after_merge() const
Returns true if the function is redundant_after_merge.
Definition mraimpl.h:268
void mulXXvec(const FunctionImpl< L, NDIM > *left, const std::vector< const FunctionImpl< R, NDIM > * > &vright, const std::vector< FunctionImpl< T, NDIM > * > &vresult, double tol, bool fence)
Definition funcimpl.h:3318
Key< NDIM > keyT
Type of key.
Definition funcimpl.h:954
friend hashT hash_value(const std::shared_ptr< FunctionImpl< T, NDIM > > impl)
Hash a shared_ptr to FunctionImpl.
Definition funcimpl.h:7297
std::vector< Vector< double, NDIM > > special_points
special points for further refinement (needed for composite functions or multiplication)
Definition funcimpl.h:976
bool truncate_on_project
If true projection inserts at level n-1 not n.
Definition funcimpl.h:981
AtomicInt small
Definition funcimpl.h:1001
static void do_dot_localX(const typename mapT::iterator lstart, const typename mapT::iterator lend, typename FunctionImpl< R, NDIM >::mapT *rmap_ptr, const bool sym, Tensor< TENSOR_RESULT_TYPE(T, R)> *result_ptr, Mutex *mutex)
Definition funcimpl.h:6036
bool is_on_demand() const
Definition mraimpl.h:283
double err_box(const keyT &key, const nodeT &node, const opT &func, int npt, const Tensor< double > &qx, const Tensor< double > &quad_phit, const Tensor< double > &quad_phiw) const
Returns the square of the error norm in the box labeled by key.
Definition funcimpl.h:5512
void accumulate_timer(const double time) const
Definition mraimpl.h:352
void trickle_down_op(const keyT &key, const coeffT &s)
sum all the contributions from all scales after applying an operator in mod-NS form
Definition mraimpl.h:1365
static void do_inner_localX(const typename mapT::iterator lstart, const typename mapT::iterator lend, typename FunctionImpl< R, NDIM >::mapT *rmap_ptr, const bool sym, Tensor< TENSOR_RESULT_TYPE(T, R) > *result_ptr, Mutex *mutex)
Definition funcimpl.h:5955
void mulXXveca(const keyT &key, const FunctionImpl< L, NDIM > *left, const Tensor< L > &lcin, const std::vector< const FunctionImpl< R, NDIM > * > vrightin, const std::vector< Tensor< R > > &vrcin, const std::vector< FunctionImpl< T, NDIM > * > vresultin, double tol)
Definition funcimpl.h:2954
void set_thresh(double value)
Definition mraimpl.h:331
Tensor< double > print_plane_local(const int xaxis, const int yaxis, const coordT &el2)
collect the data for a plot of the MRA structure locally on each node
Definition mraimpl.h:423
void sock_it_to_me_too(const keyT &key, const RemoteReference< FutureImpl< std::pair< keyT, coeffT > > > &ref) const
Definition mraimpl.h:2849
void broaden_op(const keyT &key, const std::vector< Future< bool > > &v)
Definition mraimpl.h:1281
void print_plane(const std::string filename, const int xaxis, const int yaxis, const coordT &el2)
Print a plane ("xy", "xz", or "yz") containing the point x to file.
Definition mraimpl.h:403
void print_tree(std::ostream &os=std::cout, Level maxlevel=10000) const
Definition mraimpl.h:2672
void project_refine_op(const keyT &key, bool do_refine, const std::vector< Vector< double, NDIM > > &specialpts)
Definition mraimpl.h:2458
void scale_oop(const Q q, const FunctionImpl< F, NDIM > &f, bool fence)
Out-of-place scale by a constant.
Definition funcimpl.h:7264
T typeT
Definition funcimpl.h:949
std::size_t tree_size() const
Returns the size of the tree structure of the function ... collective global sum.
Definition mraimpl.h:1882
ConcurrentHashMap< keyT, mapvecT > mapT
Type of the map returned by make_key_vec_map.
Definition funcimpl.h:5883
void add_scalar_inplace(T t, bool fence)
Adds a constant to the function. Local operation, optional fence.
Definition mraimpl.h:2536
void forward_traverse(const coeff_opT &coeff_op, const apply_opT &apply_op, const keyT &key) const
traverse a non-existing tree
Definition funcimpl.h:3755
tensorT downsample(const keyT &key, const std::vector< Future< coeffT > > &v) const
downsample the sum coefficients of level n+1 to sum coeffs on level n
Definition mraimpl.h:1201
void abs_square_inplace(bool fence)
Definition mraimpl.h:3132
FunctionImpl(const FunctionImpl< Q, NDIM > &other, const std::shared_ptr< WorldDCPmapInterface< Key< NDIM > > > &pmap, bool dozero)
Copy constructor.
Definition funcimpl.h:1071
void refine(const opT &op, bool fence)
Definition funcimpl.h:4615
static mapT make_key_vec_map(const std::vector< const FunctionImpl< T, NDIM > * > &v)
Returns map of union of local keys to vector of indexes of functions containing that key.
Definition funcimpl.h:5904
void put_in_box(ProcessID from, long nl, long ni) const
Definition mraimpl.h:824
void unary_op_value_inplace(const opT &op, bool fence)
Definition funcimpl.h:2934
std::pair< const keyT, nodeT > datumT
Type of entry in container.
Definition funcimpl.h:958
Timer timer_accumulate
Definition funcimpl.h:995
TensorArgs get_tensor_args() const
Definition mraimpl.h:322
void unaryXXa(const keyT &key, const FunctionImpl< Q, NDIM > *func, const opT &op)
Definition funcimpl.h:3236
void make_Vphi_only(const opT &leaf_op, FunctionImpl< T, NDIM > *ket, FunctionImpl< T, LDIM > *v1, FunctionImpl< T, LDIM > *v2, FunctionImpl< T, LDIM > *p1, FunctionImpl< T, LDIM > *p2, FunctionImpl< T, NDIM > *eri, const bool fence=true)
assemble the function V*phi using V and phi given from the functor
Definition funcimpl.h:4430
void average(const implT &rhs)
take the average of two functions, similar to: this=0.5*(this+rhs)
Definition mraimpl.h:1088
void recursive_apply(opT &apply_op, const FunctionImpl< T, LDIM > *fimpl, const FunctionImpl< T, LDIM > *gimpl, const bool fence)
traverse a non-existing tree, make its coeffs and apply an operator
Definition funcimpl.h:5265
void diff(const DerivativeBase< T, NDIM > *D, const implT *f, bool fence)
Definition mraimpl.h:946
void square_inplace(bool fence)
Pointwise squaring of function with optional global fence.
Definition mraimpl.h:3121
void remove_internal_coefficients(const bool fence)
Definition mraimpl.h:1517
void compute_snorm_and_dnorm(bool fence=true)
compute norm of s and d coefficients for all nodes
Definition mraimpl.h:1131
std::vector< unsigned char > serialize_remote_coeffs()
invoked by copy_remote_coeffs_from_pid to serialize local coeffs
Definition funcimpl.h:1183
long box_leaf[1000]
Definition funcimpl.h:3332
void standard(bool fence)
Changes non-standard compressed form to standard compressed form.
Definition mraimpl.h:1765
void multiop_values_doit(const keyT &key, const opT &op, const std::vector< implT * > &v)
Definition funcimpl.h:2825
bool is_nonstandard_with_leaves() const
Definition mraimpl.h:278
GenTensor< Q > values2NScoeffs(const keyT &key, const GenTensor< Q > &values) const
convert function values of the a child generation directly to NS coeffs
Definition funcimpl.h:1913
int truncate_mode
0=default=(|d|<thresh), 1=(|d|<thresh/2^n), 2=(|d|<thresh/4^n);
Definition funcimpl.h:979
void multiop_values(const opT &op, const std::vector< implT * > &v)
Definition funcimpl.h:2842
GenTensor< Q > NScoeffs2values(const keyT &key, const GenTensor< Q > &coeff, const bool s_only) const
convert S or NS coeffs to values on a 2k grid of the children
Definition funcimpl.h:1828
static std::enable_if_t< std::is_floating_point_v< Real >, Real > conj(const Real x)
Definition funcimpl.h:6076
FunctionNode holds the coefficients, etc., at each node of the 2^NDIM-tree.
Definition funcimpl.h:127
FunctionNode< Q, NDIM > convert() const
Copy with possible type conversion of coefficients, copying all other state.
Definition funcimpl.h:194
GenTensor< T > coeffT
Definition funcimpl.h:129
bool has_coeff() const
Returns true if there are coefficients in this node.
Definition funcimpl.h:200
void recompute_snorm_and_dnorm(const FunctionCommonData< T, NDIM > &cdata)
Definition funcimpl.h:335
FunctionNode(const coeffT &coeff, bool has_children=false)
Constructor from given coefficients with optional children.
Definition funcimpl.h:156
FunctionNode()
Default constructor makes node without coeff or children.
Definition funcimpl.h:146
void serialize(Archive &ar)
Definition funcimpl.h:458
void consolidate_buffer(const TensorArgs &args)
Definition funcimpl.h:444
double get_dnorm() const
return the precomputed norm of the (virtual) d coefficients
Definition funcimpl.h:316
size_t size() const
Returns the number of coefficients in this node.
Definition funcimpl.h:242
void set_has_children_recursive(const typename FunctionNode< T, NDIM >::dcT &c, const Key< NDIM > &key)
Sets has_children attribute to true recurring up to ensure connected.
Definition funcimpl.h:259
FunctionNode< T, NDIM > & operator=(const FunctionNode< T, NDIM > &other)
Definition funcimpl.h:176
double snorm
norm of the s coefficients
Definition funcimpl.h:141
void clear_coeff()
Clears the coefficients (has_coeff() will subsequently return false)
Definition funcimpl.h:295
Tensor< T > tensorT
Definition funcimpl.h:130
coeffT buffer
The coefficients, if any.
Definition funcimpl.h:139
T trace_conj(const FunctionNode< T, NDIM > &rhs) const
Definition funcimpl.h:453
void scale(Q a)
Scale the coefficients of this node.
Definition funcimpl.h:301
bool is_leaf() const
Returns true if this does not have children.
Definition funcimpl.h:213
void set_has_children(bool flag)
Sets has_children attribute to value of flag.
Definition funcimpl.h:254
void accumulate(const coeffT &t, const typename FunctionNode< T, NDIM >::dcT &c, const Key< NDIM > &key, const TensorArgs &args)
Accumulate inplace and if necessary connect node to parent.
Definition funcimpl.h:416
double get_norm_tree() const
Gets the value of norm_tree.
Definition funcimpl.h:311
bool _has_children
True if there are children.
Definition funcimpl.h:138
FunctionNode(const coeffT &coeff, double norm_tree, double snorm, double dnorm, bool has_children)
Definition funcimpl.h:166
void set_snorm(const double sn)
set the precomputed norm of the (virtual) s coefficients
Definition funcimpl.h:321
coeffT _coeffs
The coefficients, if any.
Definition funcimpl.h:136
void accumulate2(const tensorT &t, const typename FunctionNode< T, NDIM >::dcT &c, const Key< NDIM > &key)
Accumulate inplace and if necessary connect node to parent.
Definition funcimpl.h:383
void reduceRank(const double &eps)
reduces the rank of the coefficients (if applicable)
Definition funcimpl.h:249
WorldContainer< Key< NDIM >, FunctionNode< T, NDIM > > dcT
Definition funcimpl.h:144
void gaxpy_inplace(const T &alpha, const FunctionNode< Q, NDIM > &other, const R &beta)
General bi-linear operation — this = this*alpha + other*beta.
Definition funcimpl.h:365
double _norm_tree
After norm_tree will contain norm of coefficients summed up tree.
Definition funcimpl.h:137
void set_is_leaf(bool flag)
Sets has_children attribute to value of !flag.
Definition funcimpl.h:280
void print_json(std::ostream &s) const
Definition funcimpl.h:466
double get_snorm() const
get the precomputed norm of the (virtual) s coefficients
Definition funcimpl.h:331
const coeffT & coeff() const
Returns a const reference to the tensor containing the coeffs.
Definition funcimpl.h:237
FunctionNode(const coeffT &coeff, double norm_tree, bool has_children)
Definition funcimpl.h:161
bool has_children() const
Returns true if this node has children.
Definition funcimpl.h:207
void set_coeff(const coeffT &coeffs)
Takes a shallow copy of the coeff — same as this->coeff()=coeff.
Definition funcimpl.h:285
void set_dnorm(const double dn)
set the precomputed norm of the (virtual) d coefficients
Definition funcimpl.h:326
double dnorm
norm of the d coefficients, also defined if there are no d coefficients
Definition funcimpl.h:140
bool is_invalid() const
Returns true if this node is invalid (no coeffs and no children)
Definition funcimpl.h:219
FunctionNode(const FunctionNode< T, NDIM > &other)
Definition funcimpl.h:170
coeffT & coeff()
Returns a non-const reference to the tensor containing the coeffs.
Definition funcimpl.h:227
void set_norm_tree(double norm_tree)
Sets the value of norm_tree.
Definition funcimpl.h:306
Implements the functionality of futures.
Definition future.h:74
A future is a possibly yet unevaluated value.
Definition future.h:369
remote_refT remote_ref(World &world) const
Returns a structure used to pass references to another process.
Definition future.h:671
RemoteReference< FutureImpl< T > > remote_refT
Definition future.h:394
Definition lowranktensor.h:59
bool is_of_tensortype(const TensorType &tt) const
Definition gentensor.h:225
GenTensor convert(const TensorArgs &targs) const
Definition gentensor.h:198
long dim(const int i) const
return the number of entries in dimension i
Definition lowranktensor.h:391
Tensor< T > full_tensor_copy() const
Definition gentensor.h:206
long ndim() const
Definition lowranktensor.h:386
void add_SVD(const GenTensor< T > &rhs, const double &eps)
Definition gentensor.h:235
constexpr bool is_full_tensor() const
Definition gentensor.h:224
const Tensor< T > & get_tensor() const
Definition gentensor.h:203
bool has_no_data() const
Definition gentensor.h:211
void normalize()
Definition gentensor.h:218
GenTensor< T > & emul(const GenTensor< T > &other)
Inplace multiply by corresponding elements of argument Tensor.
Definition lowranktensor.h:637
float_scalar_type normf() const
Definition lowranktensor.h:406
double svd_normf() const
Definition gentensor.h:213
SRConf< T > config() const
Definition gentensor.h:237
void reduce_rank(const double &eps)
Definition gentensor.h:217
long rank() const
Definition gentensor.h:212
const Tensor< T > & full_tensor() const
Definition gentensor.h:200
long size() const
Definition lowranktensor.h:488
SVDTensor< T > & get_svdtensor()
Definition gentensor.h:228
TensorType tensor_type() const
Definition gentensor.h:221
bool has_data() const
Definition gentensor.h:210
Tensor< T > reconstruct_tensor() const
Definition gentensor.h:199
GenTensor & gaxpy(const T alpha, const GenTensor &other, const T beta)
Definition lowranktensor.h:586
bool is_assigned() const
Definition gentensor.h:209
IsSupported< TensorTypeData< Q >, GenTensor< T > & >::type scale(Q fac)
Inplace multiplication by scalar of supported type (legacy name)
Definition lowranktensor.h:426
constexpr bool is_svd_tensor() const
Definition gentensor.h:222
Iterates in lexical order thru all children of a key.
Definition key.h:505
Key is the index for a node of the 2^NDIM-tree.
Definition key.h:70
Key< NDIM+LDIM > merge_with(const Key< LDIM > &rhs) const
merge with other key (ie concatenate), use level of rhs, not of this
Definition key.h:444
Level level() const
Definition key.h:169
bool is_valid() const
Checks if a key is valid.
Definition key.h:124
hashT hash() const
Definition key.h:158
Key< NDIM-VDIM > extract_complement_key(const std::array< int, VDIM > &v) const
extract a new key with the Translations complementary to the ones indicated in the v array
Definition key.h:430
Key< VDIM > extract_key(const std::array< int, VDIM > &v) const
extract a new key with the Translations indicated in the v array
Definition key.h:422
Key parent(int generation=1) const
Returns the key of the parent.
Definition key.h:290
const Vector< Translation, NDIM > & translation() const
Definition key.h:174
void break_apart(Key< LDIM > &key1, Key< KDIM > &key2) const
break key into two low-dimensional keys
Definition key.h:381
A pmap that locates children on odd levels with their even level parents.
Definition funcimpl.h:105
LevelPmap(World &world)
Definition funcimpl.h:111
const int nproc
Definition funcimpl.h:107
LevelPmap()
Definition funcimpl.h:109
ProcessID owner(const keyT &key) const
Find the owner of a given key.
Definition funcimpl.h:114
Mutex using pthread mutex operations.
Definition worldmutex.h:131
void unlock() const
Free a mutex owned by this thread.
Definition worldmutex.h:165
void lock() const
Acquire the mutex waiting if necessary.
Definition worldmutex.h:155
Range, vaguely a la Intel TBB, to encapsulate a random-access, STL-like start and end iterator with c...
Definition range.h:64
Simple structure used to manage references/pointers to remote instances.
Definition worldref.h:395
Definition SVDTensor.h:42
A simple process map.
Definition funcimpl.h:86
SimplePmap(World &world)
Definition funcimpl.h:92
const int nproc
Definition funcimpl.h:88
const ProcessID me
Definition funcimpl.h:89
ProcessID owner(const keyT &key) const
Maps key to processor.
Definition funcimpl.h:95
A slice defines a sub-range or patch of a dimension.
Definition slice.h:103
static TaskAttributes hipri()
Definition thread.h:456
Traits class to specify support of numeric types.
Definition type_data.h:56
A tensor is a multidimensional array.
Definition tensor.h:317
float_scalar_type normf() const
Returns the Frobenius norm of the tensor.
Definition tensor.h:1726
Tensor< T > & gaxpy(T alpha, const Tensor< T > &other, T beta)
Inplace generalized saxpy ... this = this*alpha + other*beta.
Definition tensor.h:1805
T sum() const
Returns the sum of all elements of the tensor.
Definition tensor.h:1662
Tensor< T > reshape(int ndimnew, const long *d)
Returns new view/tensor reshaping size/number of dimensions to conforming tensor.
Definition tensor.h:1384
T * ptr()
Returns a pointer to the internal data.
Definition tensor.h:1840
Tensor< T > mapdim(const std::vector< long > &map)
Returns new view/tensor permuting the dimensions.
Definition tensor.h:1624
IsSupported< TensorTypeData< Q >, Tensor< T > & >::type scale(Q x)
Inplace multiplication by scalar of supported type (legacy name)
Definition tensor.h:686
Tensor< T > & emul(const Tensor< T > &t)
Inplace multiply by corresponding elements of argument Tensor.
Definition tensor.h:1799
bool has_data() const
Definition tensor.h:1902
Tensor< T > fusedim(long i)
Returns new view/tensor fusing contiguous dimensions i and i+1.
Definition tensor.h:1587
Tensor< T > flat()
Returns new view/tensor rehshaping to flat (1-d) tensor.
Definition tensor.h:1555
Tensor< T > & conj()
Inplace complex conjugate.
Definition tensor.h:716
Definition function_common_data.h:169
void accumulate(const double time) const
accumulate timer
Definition function_common_data.h:183
A simple, fixed dimension vector.
Definition vector.h:64
Makes a distributed container with specified attributes.
Definition worlddc.h:1127
void process_pending()
Process pending messages.
Definition worlddc.h:1453
bool find(accessor &acc, const keyT &key)
Write access to LOCAL value by key. Returns true if found, false otherwise (always false for remote).
Definition worlddc.h:1274
bool probe(const keyT &key) const
Returns true if local data is immediately available (no communication)
Definition worlddc.h:1311
iterator begin()
Returns an iterator to the beginning of the local data (no communication)
Definition worlddc.h:1357
bool is_replicated() const
Definition worlddc.h:1227
ProcessID owner(const keyT &key) const
Returns processor that logically owns key (no communication)
Definition worlddc.h:1321
implT::const_iterator const_iterator
Definition worlddc.h:1135
void replicate(bool fence=true)
replicates this WorldContainer on all ProcessIDs
Definition worlddc.h:1249
void erase(const keyT &key)
Erases entry from container (non-blocking comm if remote)
Definition worlddc.h:1392
void replace(const pairT &datum)
Inserts/replaces key+value pair (non-blocking communication if key not local)
Definition worlddc.h:1261
iterator end()
Returns an iterator past the end of the local data (no communication)
Definition worlddc.h:1371
const std::shared_ptr< WorldDCPmapInterface< keyT > > & get_pmap() const
Returns shared pointer to the process mapping.
Definition worlddc.h:1429
bool insert(accessor &acc, const keyT &key)
Write access to LOCAL value by key. Returns true if inserted, false if already exists (throws if remo...
Definition worlddc.h:1288
bool is_distributed() const
Definition worlddc.h:1223
implT::iterator iterator
Definition worlddc.h:1134
std::size_t size() const
Returns the number of local entries (no communication)
Definition worlddc.h:1422
Future< REMFUTURE(MEMFUN_RETURNT(memfunT))> task(const keyT &key, memfunT memfun, const TaskAttributes &attr=TaskAttributes())
Adds task "resultT memfun()" in process owning item (non-blocking comm if remote)
Definition worlddc.h:1713
bool is_local(const keyT &key) const
Returns true if the key maps to the local processor (no communication)
Definition worlddc.h:1328
bool is_host_replicated() const
Definition worlddc.h:1231
Future< MEMFUN_RETURNT(memfunT)> send(const keyT &key, memfunT memfun)
Sends message "resultT memfun()" to item (non-blocking comm if remote)
Definition worlddc.h:1470
void replicate_on_hosts(bool fence=true)
replicates this WorldContainer on all hosts (one PID per host)
Definition worlddc.h:1255
implT::accessor accessor
Definition worlddc.h:1136
Interface to be provided by any process map.
Definition worlddc.h:122
void fence(bool debug=false)
Synchronizes all processes in communicator AND globally ensures no pending AM or tasks.
Definition worldgop.cc:161
Implements most parts of a globally addressable object (via unique ID).
Definition world_object.h:366
const uniqueidT & id() const
Returns the globally unique object ID.
Definition world_object.h:713
void process_pending()
To be called from derived constructor to process pending messages.
Definition world_object.h:658
ProcessID me
Rank of self.
Definition world_object.h:387
detail::task_result_type< memfnT >::futureT send(ProcessID dest, memfnT memfn) const
Definition world_object.h:733
detail::task_result_type< memfnT >::futureT task(ProcessID dest, memfnT memfn, const TaskAttributes &attr=TaskAttributes()) const
Sends task to derived class method returnT (this->*memfn)().
Definition world_object.h:1007
Future< bool > for_each(const rangeT &range, const opT &op)
Apply op(item) on all items in range.
Definition world_task_queue.h:572
void add(TaskInterface *t)
Add a new local task, taking ownership of the pointer.
Definition world_task_queue.h:466
Future< resultT > reduce(const rangeT &range, const opT &op)
Reduce op(item) for all items in range using op(sum,op(item)).
Definition world_task_queue.h:527
A parallel world class.
Definition world.h:132
static World * world_from_id(std::uint64_t id)
Convert a World ID to a World pointer.
Definition world.h:492
WorldTaskQueue & taskq
Task queue.
Definition world.h:206
std::vector< uniqueidT > get_object_ids() const
Returns a vector of all unique IDs in this World.
Definition world.h:468
ProcessID rank() const
Returns the process rank in this World (same as MPI_Comm_rank()).
Definition world.h:320
static std::vector< unsigned long > get_world_ids()
return a vector containing all world ids
Definition world.h:476
ProcessID size() const
Returns the number of processes in this World (same as MPI_Comm_size()).
Definition world.h:330
unsigned long id() const
Definition world.h:315
WorldGopInterface & gop
Global operations.
Definition world.h:207
std::optional< T * > ptr_from_id(uniqueidT id) const
Look up a local pointer from a world-wide unique ID.
Definition world.h:416
ProcessID random_proc()
Returns a random process number; that is, an integer in [0,world.size()).
Definition world.h:591
Wraps an archive around an STL vector for output.
Definition vector_archive.h:55
Wrapper for an opaque pointer for serialization purposes.
Definition archive.h:851
syntactic sugar for std::array<bool, N>
Definition array_of_bools.h:19
Class for unique global IDs.
Definition uniqueid.h:53
unsigned long get_obj_id() const
Access the object ID.
Definition uniqueid.h:97
unsigned long get_world_id() const
Access the World ID.
Definition uniqueid.h:90
static const double R
Definition csqrt.cc:46
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 double lo
Definition dirac-hatom.cc:23
@ upper
Definition dirac-hatom.cc:15
Provides FunctionDefaults and utilities for coordinate transformation.
auto T(World &world, response_space &f) -> response_space
Definition global_functions.cc:28
archive_array< unsigned char > wrap_opaque(const T *, unsigned int)
Factory function to wrap a pointer to contiguous data as an opaque (uchar) archive_array.
Definition archive.h:926
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:2518
Tensor< TENSOR_RESULT_TYPE(T, Q) > & fast_transform(const Tensor< T > &t, const Tensor< Q > &c, Tensor< TENSOR_RESULT_TYPE(T, Q) > &result, Tensor< TENSOR_RESULT_TYPE(T, Q) > &workspace)
Restricted but heavily optimized form of transform()
Definition tensor.h:2459
const double beta
Definition gygi_soltion.cc:62
static const double v
Definition hatom_sf_dirac.cc:20
Tensor< double > op(const Tensor< double > &x)
Definition kain.cc:508
Multidimension Key for MRA tree and associated iterators.
static double pow(const double *a, const double *b)
Definition lda.h:74
#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_ASSERT(condition)
Assert a condition that should be free of side-effects since in release builds this might be a no-op.
Definition madness_exception.h:134
#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
Header to declare stuff which has not yet found a home.
constexpr double pi
Mathematical constant .
Definition constants.h:48
MemFuncWrapper< objT *, memfnT, typename result_of< memfnT >::type > wrap_mem_fn(objT &obj, memfnT memfn)
Create a member function wrapper (MemFuncWrapper) from an object and a member function pointer.
Definition mem_func_wrapper.h:251
void combine_hash(hashT &seed, hashT hash)
Internal use only.
Definition worldhash.h:248
Namespace for all elements and tools of MADNESS.
Definition DFParameters.h:10
std::ostream & operator<<(std::ostream &os, const particle< PDIM > &p)
Definition lowrankfunction.h:401
static const char * filename
Definition legendre.cc:96
static const std::vector< Slice > ___
Entire dimension.
Definition slice.h:128
static double cpu_time()
Returns the cpu time in seconds relative to an arbitrary origin.
Definition timers.h:127
GenTensor< TENSOR_RESULT_TYPE(R, Q)> general_transform(const GenTensor< R > &t, const Tensor< Q > c[])
Definition gentensor.h:274
response_space scale(response_space a, double b)
bool nearlyEqual(double a, double b, double epsilon=1e-9)
Definition numerics.cc:11
void finalize()
Call this once at the very end of your main program instead of MPI_Finalize().
Definition world.cc:235
void norm_tree(World &world, const std::vector< Function< T, NDIM > > &v, bool fence=true)
Makes the norm tree for all functions in a vector.
Definition vmra.h:1205
std::vector< Function< TENSOR_RESULT_TYPE(T, R), NDIM > > transform(World &world, const std::vector< Function< T, NDIM > > &v, const Tensor< R > &c, bool fence=true)
Transforms a vector of functions according to new[i] = sum[j] old[j]*c[j,i].
Definition vmra.h:731
TreeState
Definition funcdefaults.h:59
@ nonstandard_after_apply
s and d coeffs, state after operator application
Definition funcdefaults.h:64
@ redundant_after_merge
s coeffs everywhere, must be summed up to yield the result
Definition funcdefaults.h:66
@ reconstructed
s coeffs at the leaves only
Definition funcdefaults.h:60
@ nonstandard
s and d coeffs in internal nodes
Definition funcdefaults.h:62
@ redundant
s coeffs everywhere
Definition funcdefaults.h:65
static Tensor< double > weights[max_npt+1]
Definition legendre.cc:99
int64_t Translation
Definition key.h:58
Key< NDIM > displacement(const Key< NDIM > &source, const Key< NDIM > &target)
given a source and a target, return the displacement in translation
Definition key.h:490
static const Slice _(0,-1, 1)
std::shared_ptr< FunctionFunctorInterface< double, 3 > > func(new opT(g))
void change_tensor_type(GenTensor< T > &t, const TensorArgs &targs)
change representation to targ.tt
Definition gentensor.h:284
int Level
Definition key.h:59
std::enable_if< std::is_base_of< ProjectorBase, projT >::value, OuterProjector< projT, projQ > >::type outer(const projT &p0, const projQ &p1)
Definition projector.h:457
int RandomValue< int >()
Random int.
Definition ran.cc:250
static double pop(std::vector< double > &v)
Definition SCF.cc:115
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:226
Tensor< T > fcube(const Key< NDIM > &, T(*f)(const Vector< double, NDIM > &), const Tensor< double > &)
Definition mraimpl.h:2133
TensorType
low rank representations of tensors (see gentensor.h)
Definition gentensor.h:120
@ TT_2D
Definition gentensor.h:120
@ TT_FULL
Definition gentensor.h:120
NDIM & f
Definition mra.h:2543
void error(const char *msg)
Definition world.cc:142
NDIM const Function< R, NDIM > & g
Definition mra.h:2543
std::size_t hashT
The hash value type.
Definition worldhash.h:145
static const int kmax
Definition twoscale.cc:52
double inner(response_space &a, response_space &b)
Definition response_functions.h:639
GenTensor< TENSOR_RESULT_TYPE(R, Q)> transform_dir(const GenTensor< R > &t, const Tensor< Q > &c, const int axis)
Definition lowranktensor.h:1106
std::string name(const FuncType &type, const int ex=-1)
Definition ccpairfunction.h:28
void mxmT(long dimi, long dimj, long dimk, T *MADNESS_RESTRICT c, const T *a, const T *b)
Matrix += Matrix * matrix transpose ... MKL interface version.
Definition mxm.h:225
Function< T, NDIM > copy(const Function< T, NDIM > &f, const std::shared_ptr< WorldDCPmapInterface< Key< NDIM > > > &pmap, bool fence=true)
Create a new copy of the function with different distribution and optional fence.
Definition mra.h:2111
static const int MAXK
The maximum wavelet order presently supported.
Definition funcdefaults.h:54
static long abs(long a)
Definition tensor.h:218
const double cc
Definition navstokes_cosines.cc:107
static const double b
Definition nonlinschro.cc:119
static const double d
Definition nonlinschro.cc:121
static const double a
Definition nonlinschro.cc:118
Defines simple templates for printing to std::cout "a la Python".
double Q(double a)
Definition relops.cc:20
static const double c
Definition relops.cc:10
static const double L
Definition rk.cc:46
static const double thresh
Definition rk.cc:45
Definition test_ar.cc:204
Key parent() const
Definition test_tree.cc:68
hashT hash() const
Definition test_dc.cc:54
Definition test_ccpairfunction.cc:22
given a ket and the 1- and 2-electron potentials, construct the function V phi
Definition funcimpl.h:4090
implT * result
where to construct Vphi, no need to track parents
Definition funcimpl.h:4098
bool have_v2() const
Definition funcimpl.h:4107
ctL iav1
Definition funcimpl.h:4102
Vphi_op_NS(implT *result, const opT &leaf_op, const ctT &iaket, const ctL &iap1, const ctL &iap2, const ctL &iav1, const ctL &iav2, const implT *eri)
Definition funcimpl.h:4116
ctL iap1
Definition funcimpl.h:4101
bool have_v1() const
Definition funcimpl.h:4106
std::pair< bool, coeffT > continue_recursion(const std::vector< bool > child_is_leaf, const tensorT &coeffs, const keyT &key) const
loop over all children and either insert their sum coeffs or continue the recursion
Definition funcimpl.h:4182
opT leaf_op
deciding if a given FunctionNode will be a leaf node
Definition funcimpl.h:4099
std::pair< coeffT, double > make_sum_coeffs(const keyT &key) const
make the sum coeffs for key
Definition funcimpl.h:4275
CoeffTracker< T, NDIM > ctT
Definition funcimpl.h:4095
ctL iap2
the particles 1 and 2 (exclusive with ket)
Definition funcimpl.h:4101
bool have_ket() const
Definition funcimpl.h:4105
const implT * eri
2-particle potential, must be on-demand
Definition funcimpl.h:4103
CoeffTracker< T, LDIM > ctL
Definition funcimpl.h:4096
std::pair< bool, coeffT > operator()(const Key< NDIM > &key) const
make and insert the coefficients into result's tree
Definition funcimpl.h:4127
void serialize(const Archive &ar)
serialize this (needed for use in recursive_op)
Definition funcimpl.h:4356
Vphi_op_NS< opT, LDIM > this_type
Definition funcimpl.h:4094
ctT iaket
the ket of a pair function (exclusive with p1, p2)
Definition funcimpl.h:4100
double compute_error_from_inaccurate_refinement(const keyT &key, const tensorT &ceri) const
the error is computed from the d coefficients of the constituent functions
Definition funcimpl.h:4228
void accumulate_into_result(const Key< NDIM > &key, const coeffT &coeff) const
Definition funcimpl.h:4110
this_type make_child(const keyT &child) const
Definition funcimpl.h:4327
tensorT eri_coeffs(const keyT &key) const
Definition funcimpl.h:4208
ctL iav2
potentials for particles 1 and 2
Definition funcimpl.h:4102
bool have_eri() const
Definition funcimpl.h:4108
this_type forward_ctor(implT *result1, const opT &leaf_op, const ctT &iaket1, const ctL &iap11, const ctL &iap21, const ctL &iav11, const ctL &iav21, const implT *eri1)
Definition funcimpl.h:4349
Vphi_op_NS()
Definition funcimpl.h:4115
Future< this_type > activate() const
Definition funcimpl.h:4338
bool randomize() const
Definition funcimpl.h:4092
add two functions f and g: result=alpha * f + beta * g
Definition funcimpl.h:3600
bool randomize() const
Definition funcimpl.h:3605
Future< this_type > activate() const
retrieve the coefficients (parent coeffs might be remote)
Definition funcimpl.h:3635
add_op(const ctT &f, const ctT &g, const double alpha, const double beta)
Definition funcimpl.h:3613
ctT f
tracking coeffs of first and second addend
Definition funcimpl.h:3608
double alpha
prefactor for f, g
Definition funcimpl.h:3610
add_op this_type
Definition funcimpl.h:3603
CoeffTracker< T, NDIM > ctT
Definition funcimpl.h:3602
void serialize(const Archive &ar)
Definition funcimpl.h:3647
ctT g
Definition funcimpl.h:3608
std::pair< bool, coeffT > operator()(const keyT &key) const
if we are at the bottom of the trees, return the sum of the coeffs
Definition funcimpl.h:3617
double beta
Definition funcimpl.h:3610
this_type make_child(const keyT &child) const
Definition funcimpl.h:3630
this_type forward_ctor(const ctT &f1, const ctT &g1, const double alpha, const double beta)
taskq-compatible ctor
Definition funcimpl.h:3643
Definition funcimpl.h:3203
opT op
Definition funcimpl.h:3206
opT::resultT resultT
Definition funcimpl.h:3204
Tensor< resultT > operator()(const Key< NDIM > &key, const Tensor< Q > &t) const
Definition funcimpl.h:3213
coeff_value_adaptor(const FunctionImpl< Q, NDIM > *impl_func, const opT &op)
Definition funcimpl.h:3209
const FunctionImpl< Q, NDIM > * impl_func
Definition funcimpl.h:3205
coeff_value_adaptor()=default
void serialize(Archive &ar)
Definition funcimpl.h:3222
merge the coefficent boxes of this into result's tree
Definition funcimpl.h:2445
Range< typename dcT::const_iterator > rangeT
Definition funcimpl.h:2446
do_accumulate_trees()=default
void serialize(const Archive &ar)
Definition funcimpl.h:2463
FunctionImpl< Q, NDIM > * result
Definition funcimpl.h:2447
do_accumulate_trees(FunctionImpl< Q, NDIM > &result, const T alpha)
Definition funcimpl.h:2450
T alpha
Definition funcimpl.h:2448
bool operator()(typename rangeT::iterator &it) const
return the norm of the difference of this node and its "mirror" node
Definition funcimpl.h:2454
"put" this on g
Definition funcimpl.h:2656
Range< typename dcT::const_iterator > rangeT
Definition funcimpl.h:2657
void serialize(const Archive &ar)
Definition funcimpl.h:2685
implT * g
Definition funcimpl.h:2659
do_average()
Definition funcimpl.h:2661
bool operator()(typename rangeT::iterator &it) const
iterator it points to this
Definition funcimpl.h:2665
do_average(implT &g)
Definition funcimpl.h:2662
change representation of nodes' coeffs to low rank, optional fence
Definition funcimpl.h:2689
Range< typename dcT::iterator > rangeT
Definition funcimpl.h:2690
void serialize(const Archive &ar)
Definition funcimpl.h:2713
TensorArgs targs
Definition funcimpl.h:2693
do_change_tensor_type(const TensorArgs &targs, implT &g)
Definition funcimpl.h:2699
bool operator()(typename rangeT::iterator &it) const
Definition funcimpl.h:2702
implT * f
Definition funcimpl.h:2694
do_change_tensor_type()=default
check symmetry wrt particle exchange
Definition funcimpl.h:2362
Range< typename dcT::const_iterator > rangeT
Definition funcimpl.h:2363
double operator()(typename rangeT::iterator &it) const
return the norm of the difference of this node and its "mirror" node
Definition funcimpl.h:2369
do_check_symmetry_local()
Definition funcimpl.h:2365
void serialize(const Archive &ar)
Definition funcimpl.h:2432
double operator()(double a, double b) const
Definition funcimpl.h:2428
do_check_symmetry_local(const implT &f)
Definition funcimpl.h:2366
const implT * f
Definition funcimpl.h:2364
compute the norm of the wavelet coefficients
Definition funcimpl.h:4497
Range< typename dcT::iterator > rangeT
Definition funcimpl.h:4498
bool operator()(typename rangeT::iterator &it) const
Definition funcimpl.h:4504
do_compute_snorm_and_dnorm(const FunctionCommonData< T, NDIM > &cdata)
Definition funcimpl.h:4501
const FunctionCommonData< T, NDIM > & cdata
Definition funcimpl.h:4500
Definition funcimpl.h:2716
TensorArgs targs
Definition funcimpl.h:2720
do_consolidate_buffer()=default
bool operator()(typename rangeT::iterator &it) const
Definition funcimpl.h:2725
Range< typename dcT::iterator > rangeT
Definition funcimpl.h:2717
do_consolidate_buffer(const TensorArgs &targs)
Definition funcimpl.h:2724
void serialize(const Archive &ar)
Definition funcimpl.h:2729
Definition funcimpl.h:1476
double operator()(double val) const
Definition funcimpl.h:1482
double limit
Definition funcimpl.h:1477
do_convert_to_color(const double limit, const bool log)
Definition funcimpl.h:1481
bool log
Definition funcimpl.h:1478
do_convert_to_color()=default
static double lower()
Definition funcimpl.h:1479
compute the inner product of this range with other
Definition funcimpl.h:5821
do_dot_local(const FunctionImpl< R, NDIM > *other, const bool leaves_only)
Definition funcimpl.h:5826
bool leaves_only
Definition funcimpl.h:5823
typedef TENSOR_RESULT_TYPE(T, R) resultT
resultT operator()(resultT a, resultT b) const
Definition funcimpl.h:5854
const FunctionImpl< R, NDIM > * other
Definition funcimpl.h:5822
void serialize(const Archive &ar)
Definition funcimpl.h:5858
resultT operator()(typename dcT::const_iterator &it) const
Definition funcimpl.h:5828
functor for the gaxpy_inplace method
Definition funcimpl.h:1264
FunctionImpl< T, NDIM > * f
prefactor for current function impl
Definition funcimpl.h:1266
do_gaxpy_inplace(FunctionImpl< T, NDIM > *f, T alpha, R beta)
Definition funcimpl.h:1270
bool operator()(typename rangeT::iterator &it) const
Definition funcimpl.h:1271
R beta
prefactor for other function impl
Definition funcimpl.h:1268
void serialize(Archive &ar)
Definition funcimpl.h:1279
Range< typename FunctionImpl< Q, NDIM >::dcT::const_iterator > rangeT
Definition funcimpl.h:1265
T alpha
the current function impl
Definition funcimpl.h:1267
do_gaxpy_inplace()=default
Definition funcimpl.h:6743
const bool do_leaves
start with leaf nodes instead of initial_level
Definition funcimpl.h:6747
T operator()(T a, T b) const
Definition funcimpl.h:6765
do_inner_ext_local_ffi(const std::shared_ptr< FunctionFunctorInterface< T, NDIM > > f, const implT *impl, const bool leaf_refine, const bool do_leaves)
Definition funcimpl.h:6749
void serialize(const Archive &ar)
Definition funcimpl.h:6769
const bool leaf_refine
Definition funcimpl.h:6746
const std::shared_ptr< FunctionFunctorInterface< T, NDIM > > fref
Definition funcimpl.h:6744
T operator()(typename dcT::const_iterator &it) const
Definition funcimpl.h:6753
const implT * impl
Definition funcimpl.h:6745
compute the inner product of this range with other
Definition funcimpl.h:5684
const FunctionImpl< T, NDIM > * bra
Definition funcimpl.h:5685
void serialize(const Archive &ar)
Definition funcimpl.h:5800
const FunctionImpl< R, NDIM > * ket
Definition funcimpl.h:5686
typedef TENSOR_RESULT_TYPE(T, R) resultT
bool leaves_only
Definition funcimpl.h:5687
do_inner_local_on_demand(const FunctionImpl< T, NDIM > *bra, const FunctionImpl< R, NDIM > *ket, const bool leaves_only=true)
Definition funcimpl.h:5690
resultT operator()(resultT a, resultT b) const
Definition funcimpl.h:5796
resultT operator()(typename dcT::const_iterator &it) const
Definition funcimpl.h:5693
compute the inner product of this range with other
Definition funcimpl.h:5623
resultT operator()(resultT a, resultT b) const
Definition funcimpl.h:5656
bool leaves_only
Definition funcimpl.h:5625
void serialize(const Archive &ar)
Definition funcimpl.h:5660
do_inner_local(const FunctionImpl< R, NDIM > *other, const bool leaves_only)
Definition funcimpl.h:5628
const FunctionImpl< R, NDIM > * other
Definition funcimpl.h:5624
resultT operator()(typename dcT::const_iterator &it) const
Definition funcimpl.h:5630
typedef TENSOR_RESULT_TYPE(T, R) resultT
keep only the sum coefficients in each node
Definition funcimpl.h:2316
Range< typename dcT::iterator > rangeT
Definition funcimpl.h:2317
do_keep_sum_coeffs(implT *impl)
constructor need impl for cdata
Definition funcimpl.h:2321
implT * impl
Definition funcimpl.h:2318
void serialize(const Archive &ar)
Definition funcimpl.h:2330
bool operator()(typename rangeT::iterator &it) const
Definition funcimpl.h:2323
mirror dimensions of this, write result on f
Definition funcimpl.h:2590
do_map_and_mirror()=default
bool operator()(typename rangeT::iterator &it) const
Definition funcimpl.h:2600
implT * f
Definition funcimpl.h:2594
std::vector< long > mirror
Definition funcimpl.h:2593
void serialize(const Archive &ar)
Definition funcimpl.h:2647
Range< typename dcT::iterator > rangeT
Definition funcimpl.h:2591
std::vector< long > map
Definition funcimpl.h:2593
do_map_and_mirror(const std::vector< long > map, const std::vector< long > mirror, implT &f)
Definition funcimpl.h:2597
map this on f
Definition funcimpl.h:2510
do_mapdim(const std::vector< long > map, implT &f)
Definition funcimpl.h:2517
void serialize(const Archive &ar)
Definition funcimpl.h:2533
Range< typename dcT::iterator > rangeT
Definition funcimpl.h:2511
bool operator()(typename rangeT::iterator &it) const
Definition funcimpl.h:2519
std::vector< long > map
Definition funcimpl.h:2513
do_mapdim()
Definition funcimpl.h:2516
implT * f
Definition funcimpl.h:2514
merge the coefficient boxes of this into other's tree
Definition funcimpl.h:2474
bool operator()(typename rangeT::iterator &it) const
return the norm of the difference of this node and its "mirror" node
Definition funcimpl.h:2484
Range< typename dcT::const_iterator > rangeT
Definition funcimpl.h:2475
FunctionImpl< Q, NDIM > * other
Definition funcimpl.h:2476
do_merge_trees(const T alpha, const R beta, FunctionImpl< Q, NDIM > &other)
Definition funcimpl.h:2480
T alpha
Definition funcimpl.h:2477
do_merge_trees()
Definition funcimpl.h:2479
R beta
Definition funcimpl.h:2478
void serialize(const Archive &ar)
Definition funcimpl.h:2503
mirror dimensions of this, write result on f
Definition funcimpl.h:2540
bool operator()(typename rangeT::iterator &it) const
Definition funcimpl.h:2549
implT * f
Definition funcimpl.h:2544
Range< typename dcT::iterator > rangeT
Definition funcimpl.h:2541
do_mirror()
Definition funcimpl.h:2546
do_mirror(const std::vector< long > mirror, implT &f)
Definition funcimpl.h:2547
void serialize(const Archive &ar)
Definition funcimpl.h:2583
std::vector< long > mirror
Definition funcimpl.h:2543
Definition funcimpl.h:5596
double operator()(typename dcT::const_iterator &it) const
Definition funcimpl.h:5597
void serialize(const Archive &ar)
Definition funcimpl.h:5612
double operator()(double a, double b) const
Definition funcimpl.h:5608
laziness
Definition funcimpl.h:4754
void serialize(Archive &ar)
Definition funcimpl.h:4763
Key< OPDIM > d
Definition funcimpl.h:4755
Key< OPDIM > key
Definition funcimpl.h:4755
keyT dest
Definition funcimpl.h:4756
double fac
Definition funcimpl.h:4757
do_op_args(const Key< OPDIM > &key, const Key< OPDIM > &d, const keyT &dest, double tol, double fac, double cnorm)
Definition funcimpl.h:4760
double cnorm
Definition funcimpl.h:4757
double tol
Definition funcimpl.h:4757
reduce the rank of the nodes, optional fence
Definition funcimpl.h:2336
do_reduce_rank(const TensorArgs &targs)
Definition funcimpl.h:2344
TensorArgs args
Definition funcimpl.h:2340
bool operator()(typename rangeT::iterator &it) const
Definition funcimpl.h:2350
Range< typename dcT::iterator > rangeT
Definition funcimpl.h:2337
do_reduce_rank(const double &thresh)
Definition funcimpl.h:2345
void serialize(const Archive &ar)
Definition funcimpl.h:2356
Changes non-standard compressed form to standard compressed form.
Definition funcimpl.h:4718
bool operator()(typename rangeT::iterator &it) const
Definition funcimpl.h:4729
do_standard(implT *impl)
Definition funcimpl.h:4726
Range< typename dcT::iterator > rangeT
Definition funcimpl.h:4719
void serialize(const Archive &ar)
Definition funcimpl.h:4746
implT * impl
Definition funcimpl.h:4722
given an NS tree resulting from a convolution, truncate leafs if appropriate
Definition funcimpl.h:2257
void serialize(const Archive &ar)
Definition funcimpl.h:2277
const implT * f
Definition funcimpl.h:2259
bool operator()(typename rangeT::iterator &it) const
Definition funcimpl.h:2263
Range< typename dcT::iterator > rangeT
Definition funcimpl.h:2258
do_truncate_NS_leafs(const implT *f)
Definition funcimpl.h:2261
Definition funcimpl.h:2735
Range< typename dcT::iterator > rangeT
Definition funcimpl.h:2736
bool operator()(typename rangeT::iterator &it) const
Definition funcimpl.h:2740
implT * impl
Definition funcimpl.h:2737
void serialize(const Archive &ar)
Definition funcimpl.h:2758
opT op
Definition funcimpl.h:2738
do_unary_op_value_inplace(implT *impl, const opT &op)
Definition funcimpl.h:2739
Hartree product of two LDIM functions to yield a NDIM = 2*LDIM function.
Definition funcimpl.h:3683
this_type forward_ctor(implT *result1, const ctL &p11, const ctL &p22, const leaf_opT &leaf_op)
Definition funcimpl.h:3739
bool randomize() const
Definition funcimpl.h:3684
void serialize(const Archive &ar)
Definition funcimpl.h:3743
hartree_op(implT *result, const ctL &p11, const ctL &p22, const leaf_opT &leaf_op)
Definition funcimpl.h:3695
CoeffTracker< T, LDIM > ctL
Definition funcimpl.h:3687
ctL p2
tracking coeffs of the two lo-dim functions
Definition funcimpl.h:3690
leaf_opT leaf_op
determine if a given node will be a leaf node
Definition funcimpl.h:3691
hartree_op()
Definition funcimpl.h:3694
implT * result
where to construct the pair function
Definition funcimpl.h:3689
hartree_op< LDIM, leaf_opT > this_type
Definition funcimpl.h:3686
std::pair< bool, coeffT > operator()(const Key< NDIM > &key) const
Definition funcimpl.h:3700
ctL p1
Definition funcimpl.h:3690
this_type make_child(const keyT &child) const
Definition funcimpl.h:3723
Future< this_type > activate() const
Definition funcimpl.h:3732
perform this multiplication: h(1,2) = f(1,2) * g(1)
Definition funcimpl.h:3491
multiply_op()
Definition funcimpl.h:3503
ctL g
Definition funcimpl.h:3500
Future< this_type > activate() const
Definition funcimpl.h:3582
CoeffTracker< T, LDIM > ctL
Definition funcimpl.h:3495
implT * h
the result function h(1,2) = f(1,2) * g(1)
Definition funcimpl.h:3498
CoeffTracker< T, NDIM > ctT
Definition funcimpl.h:3494
std::pair< bool, coeffT > operator()(const Key< NDIM > &key) const
apply this on a FunctionNode of f and g of Key key
Definition funcimpl.h:3530
this_type forward_ctor(implT *h1, const ctT &f1, const ctL &g1, const int particle)
Definition funcimpl.h:3589
static bool randomize()
Definition funcimpl.h:3493
int particle
if g is g(1) or g(2)
Definition funcimpl.h:3501
ctT f
Definition funcimpl.h:3499
multiply_op< LDIM > this_type
Definition funcimpl.h:3496
multiply_op(implT *h1, const ctT &f1, const ctL &g1, const int particle1)
Definition funcimpl.h:3505
bool screen(const coeffT &fcoeff, const coeffT &gcoeff, const keyT &key) const
return true if this will be a leaf node
Definition funcimpl.h:3511
this_type make_child(const keyT &child) const
Definition funcimpl.h:3572
void serialize(const Archive &ar)
Definition funcimpl.h:3593
Definition funcimpl.h:3969
coeffT val_lhs
Definition funcimpl.h:3970
double lo
Definition funcimpl.h:3973
double lo1
Definition funcimpl.h:3973
long oversampling
Definition funcimpl.h:3971
pointwise_multiplier()=default
double error
Definition funcimpl.h:3972
tensorT operator()(const Key< NDIM > key, const tensorT &coeff_rhs)
multiply values of rhs and lhs, result on rhs, rhs and lhs are of the same dimensions
Definition funcimpl.h:3988
coeffT coeff_lhs
Definition funcimpl.h:3970
void serialize(const Archive &ar)
Definition funcimpl.h:4076
double lo2
Definition funcimpl.h:3973
double hi1
Definition funcimpl.h:3973
pointwise_multiplier(const Key< NDIM > key, const coeffT &clhs)
Definition funcimpl.h:3976
coeffT operator()(const Key< NDIM > key, const tensorT &coeff_rhs, const int particle)
multiply values of rhs and lhs, result on rhs, rhs and lhs are of differnet dimensions
Definition funcimpl.h:4033
double hi2
Definition funcimpl.h:3973
double hi
Definition funcimpl.h:3973
project the low-dim function g on the hi-dim function f: result(x) = <f(x,y) | g(y)>
Definition funcimpl.h:7009
project_out_op(const implT *fimpl, implL1 *result, const ctL &iag, const int dim)
Definition funcimpl.h:7024
ctL iag
the low dim function g
Definition funcimpl.h:7019
FunctionImpl< T, NDIM-LDIM > implL1
Definition funcimpl.h:7014
Future< this_type > activate() const
retrieve the coefficients (parent coeffs might be remote)
Definition funcimpl.h:7103
std::pair< bool, coeffT > argT
Definition funcimpl.h:7015
const implT * fimpl
the hi dim function f
Definition funcimpl.h:7017
this_type forward_ctor(const implT *fimpl1, implL1 *result1, const ctL &iag1, const int dim1)
taskq-compatible ctor
Definition funcimpl.h:7110
this_type make_child(const keyT &child) const
Definition funcimpl.h:7094
project_out_op< LDIM > this_type
Definition funcimpl.h:7012
implL1 * result
the low dim result function
Definition funcimpl.h:7018
Future< argT > operator()(const Key< NDIM > &key) const
do the actual contraction
Definition funcimpl.h:7031
void serialize(const Archive &ar)
Definition funcimpl.h:7114
project_out_op(const project_out_op &other)
Definition funcimpl.h:7026
int dim
0: project 0..LDIM-1, 1: project LDIM..NDIM-1
Definition funcimpl.h:7020
bool randomize() const
Definition funcimpl.h:7010
CoeffTracker< T, LDIM > ctL
Definition funcimpl.h:7013
recursive part of recursive_apply
Definition funcimpl.h:5423
ctT iaf
Definition funcimpl.h:5431
recursive_apply_op2< opT > this_type
Definition funcimpl.h:5426
Future< this_type > activate() const
retrieve the coefficients (parent coeffs might be remote)
Definition funcimpl.h:5486
const opT * apply_op
need this for randomization
Definition funcimpl.h:5432
bool randomize() const
Definition funcimpl.h:5424
recursive_apply_op2(const recursive_apply_op2 &other)
Definition funcimpl.h:5439
void serialize(const Archive &ar)
Definition funcimpl.h:5502
argT finalize(const double kernel_norm, const keyT &key, const coeffT &coeff, const implT *r) const
sole purpose is to wait for the kernel norm, wrap it and send it back to caller
Definition funcimpl.h:5472
this_type make_child(const keyT &child) const
Definition funcimpl.h:5481
recursive_apply_op2()=default
recursive_apply_op2(implT *result, const ctT &iaf, const opT *apply_op)
Definition funcimpl.h:5436
std::pair< bool, coeffT > argT
Definition funcimpl.h:5428
implT * result
Definition funcimpl.h:5430
CoeffTracker< T, NDIM > ctT
Definition funcimpl.h:5427
argT operator()(const Key< NDIM > &key) const
send off the application of the operator
Definition funcimpl.h:5448
this_type forward_ctor(implT *result1, const ctT &iaf1, const opT *apply_op1)
taskq-compatible ctor
Definition funcimpl.h:5498
recursive part of recursive_apply
Definition funcimpl.h:5292
std::pair< bool, coeffT > operator()(const Key< NDIM > &key) const
make the NS-coefficients and send off the application of the operator
Definition funcimpl.h:5317
this_type forward_ctor(implT *r, const CoeffTracker< T, LDIM > &f1, const CoeffTracker< T, LDIM > &g1, const opT *apply_op1)
Definition funcimpl.h:5382
opT * apply_op
Definition funcimpl.h:5300
recursive_apply_op(const recursive_apply_op &other)
Definition funcimpl.h:5310
recursive_apply_op< opT, LDIM > this_type
Definition funcimpl.h:5295
Future< this_type > activate() const
Definition funcimpl.h:5375
bool randomize() const
Definition funcimpl.h:5293
implT * result
Definition funcimpl.h:5297
CoeffTracker< T, LDIM > iaf
Definition funcimpl.h:5298
void serialize(const Archive &ar)
Definition funcimpl.h:5387
recursive_apply_op()=default
std::pair< bool, coeffT > finalize(const double kernel_norm, const keyT &key, const coeffT &coeff) const
sole purpose is to wait for the kernel norm, wrap it and send it back to caller
Definition funcimpl.h:5357
recursive_apply_op(implT *result, const CoeffTracker< T, LDIM > &iaf, const CoeffTracker< T, LDIM > &iag, const opT *apply_op)
Definition funcimpl.h:5304
this_type make_child(const keyT &child) const
Definition funcimpl.h:5366
CoeffTracker< T, LDIM > iag
Definition funcimpl.h:5299
remove all coefficients of internal nodes
Definition funcimpl.h:2282
Range< typename dcT::iterator > rangeT
Definition funcimpl.h:2283
remove_internal_coeffs()=default
constructor need impl for cdata
bool operator()(typename rangeT::iterator &it) const
Definition funcimpl.h:2288
void serialize(const Archive &ar)
Definition funcimpl.h:2294
remove all coefficients of leaf nodes
Definition funcimpl.h:2299
bool operator()(typename rangeT::iterator &it) const
Definition funcimpl.h:2305
remove_leaf_coeffs()=default
constructor need impl for cdata
void serialize(const Archive &ar)
Definition funcimpl.h:2310
Range< typename dcT::iterator > rangeT
Definition funcimpl.h:2300
Definition funcimpl.h:4569
void serialize(Archive &ar)
Definition funcimpl.h:4573
bool operator()(const implT *f, const keyT &key, const nodeT &t) const
Definition funcimpl.h:4570
shallow-copy, pared-down version of FunctionNode, for special purpose only
Definition funcimpl.h:749
coeffT & coeff()
Definition funcimpl.h:763
GenTensor< T > coeffT
Definition funcimpl.h:750
bool is_leaf() const
Definition funcimpl.h:765
void serialize(Archive &ar)
Definition funcimpl.h:767
ShallowNode(const ShallowNode< T, NDIM > &node)
Definition funcimpl.h:758
ShallowNode(const FunctionNode< T, NDIM > &node)
Definition funcimpl.h:755
bool has_children() const
Definition funcimpl.h:764
ShallowNode()
Definition funcimpl.h:754
bool _has_children
Definition funcimpl.h:752
double dnorm
Definition funcimpl.h:753
const coeffT & coeff() const
Definition funcimpl.h:762
coeffT _coeffs
Definition funcimpl.h:751
TensorArgs holds the arguments for creating a LowRankTensor.
Definition gentensor.h:134
double thresh
Definition gentensor.h:135
TensorType tt
Definition gentensor.h:136
inserts/accumulates coefficients into impl's tree
Definition funcimpl.h:716
FunctionImpl< T, NDIM > * impl
Definition funcimpl.h:720
FunctionNode< T, NDIM > nodeT
Definition funcimpl.h:718
accumulate_op(const accumulate_op &other)=default
void operator()(const Key< NDIM > &key, const coeffT &coeff, const bool &is_leaf) const
Definition funcimpl.h:724
void serialize(Archive &ar)
Definition funcimpl.h:728
GenTensor< T > coeffT
Definition funcimpl.h:717
accumulate_op(FunctionImpl< T, NDIM > *f)
Definition funcimpl.h:722
static void load(const Archive &ar, FunctionImpl< T, NDIM > *&ptr)
Definition funcimpl.h:7336
static void load(const Archive &ar, const FunctionImpl< T, NDIM > *&ptr)
Definition funcimpl.h:7305
static void load(const Archive &ar, std::shared_ptr< FunctionImpl< T, NDIM > > &ptr)
Definition funcimpl.h:7387
static void load(const Archive &ar, std::shared_ptr< const FunctionImpl< T, NDIM > > &ptr)
Definition funcimpl.h:7371
Default load of an object via serialize(ar, t).
Definition archive.h:667
static void load(const A &ar, const U &t)
Load an object.
Definition archive.h:679
static void store(const Archive &ar, FunctionImpl< T, NDIM > *const &ptr)
Definition funcimpl.h:7361
static void store(const Archive &ar, const FunctionImpl< T, NDIM > *const &ptr)
Definition funcimpl.h:7327
static void store(const Archive &ar, const std::shared_ptr< FunctionImpl< T, NDIM > > &ptr)
Definition funcimpl.h:7396
static void store(const Archive &ar, const std::shared_ptr< const FunctionImpl< T, NDIM > > &ptr)
Definition funcimpl.h:7380
Default store of an object via serialize(ar, t).
Definition archive.h:612
static std::enable_if_t< is_output_archive_v< A > &&!std::is_function< U >::value &&(has_member_serialize_v< U, A >||has_nonmember_serialize_v< U, A >||has_freestanding_serialize_v< U, A >||has_freestanding_default_serialize_v< U, A >), void > store(const A &ar, const U &t)
Definition archive.h:622
Definition funcimpl.h:610
void serialize(Archive &ar)
Definition funcimpl.h:674
const opT * op
Definition funcimpl.h:617
hartree_convolute_leaf_op(const implT *f, const implL *g, const opT *op)
Definition funcimpl.h:621
bool operator()(const Key< NDIM > &key) const
no pre-determination
Definition funcimpl.h:625
hartree_convolute_leaf_op()=default
bool operator()(const Key< NDIM > &key, const Tensor< T > &fcoeff, const Tensor< T > &gcoeff) const
post-determination: true if f is a leaf and the result is well-represented
Definition funcimpl.h:638
const implL * g
Definition funcimpl.h:616
const FunctionImpl< T, NDIM > * f
Definition funcimpl.h:615
FunctionImpl< T, LDIM > implL
Definition funcimpl.h:613
bool do_error_leaf_op() const
Definition funcimpl.h:618
FunctionImpl< T, NDIM > implT
Definition funcimpl.h:612
bool operator()(const Key< NDIM > &key, const GenTensor< T > &coeff) const
no post-determination
Definition funcimpl.h:628
returns true if the result of a hartree_product is a leaf node (compute norm & error)
Definition funcimpl.h:500
hartree_leaf_op()=default
bool do_error_leaf_op() const
Definition funcimpl.h:505
const FunctionImpl< T, NDIM > * f
Definition funcimpl.h:503
hartree_leaf_op(const implT *f, const long &k)
Definition funcimpl.h:508
long k
Definition funcimpl.h:504
void serialize(Archive &ar)
Definition funcimpl.h:556
bool operator()(const Key< NDIM > &key, const GenTensor< T > &coeff) const
no post-determination
Definition funcimpl.h:514
bool operator()(const Key< NDIM > &key, const Tensor< T > &fcoeff, const Tensor< T > &gcoeff) const
post-determination: true if f is a leaf and the result is well-represented
Definition funcimpl.h:524
bool operator()(const Key< NDIM > &key) const
no pre-determination
Definition funcimpl.h:511
FunctionImpl< T, NDIM > implT
Definition funcimpl.h:502
insert/replaces the coefficients into the function
Definition funcimpl.h:692
insert_op()
Definition funcimpl.h:699
implT * impl
Definition funcimpl.h:698
void operator()(const keyT &key, const coeffT &coeff, const bool &is_leaf) const
Definition funcimpl.h:702
FunctionNode< T, NDIM > nodeT
Definition funcimpl.h:696
Key< NDIM > keyT
Definition funcimpl.h:694
insert_op(const insert_op &other)
Definition funcimpl.h:701
FunctionImpl< T, NDIM > implT
Definition funcimpl.h:693
GenTensor< T > coeffT
Definition funcimpl.h:695
insert_op(implT *f)
Definition funcimpl.h:700
void serialize(Archive &ar)
Definition funcimpl.h:706
Definition funcimpl.h:680
bool operator()(const Key< NDIM > &key, const GenTensor< T > &fcoeff, const GenTensor< T > &gcoeff) const
Definition funcimpl.h:682
void serialize(Archive &ar)
Definition funcimpl.h:686
void operator()(const Key< NDIM > &key, const GenTensor< T > &coeff, const bool &is_leaf) const
Definition funcimpl.h:681
Definition funcimpl.h:564
bool operator()(const Key< NDIM > &key, const double &cnorm) const
post-determination: return true if operator and coefficient norms are small
Definition funcimpl.h:585
void serialize(Archive &ar)
Definition funcimpl.h:600
const implT * f
the source or result function, needed for truncate_tol
Definition funcimpl.h:568
op_leaf_op(const opT *op, const implT *f)
Definition funcimpl.h:572
FunctionImpl< T, NDIM > implT
Definition funcimpl.h:565
const opT * op
the convolution operator
Definition funcimpl.h:567
bool do_error_leaf_op() const
Definition funcimpl.h:569
bool operator()(const Key< NDIM > &key) const
pre-determination: we can't know if this will be a leaf node before we got the final coeffs
Definition funcimpl.h:575
bool operator()(const Key< NDIM > &key, const GenTensor< T > &coeff) const
post-determination: return true if operator and coefficient norms are small
Definition funcimpl.h:578
Definition lowrankfunction.h:336
Definition funcimpl.h:736
void serialize(Archive &ar)
Definition funcimpl.h:743
bool operator()(const Key< NDIM > &key, const T &t, const R &r) const
Definition funcimpl.h:742
bool operator()(const Key< NDIM > &key, const T &t) const
Definition funcimpl.h:739
int np
Definition tdse1d.cc:165
static const double s0
Definition tdse4.cc:83
Defines and implements most of Tensor.
#define ITERATOR(t, exp)
Definition tensor_macros.h:249
#define IND
Definition tensor_macros.h:204
#define TERNARY_OPTIMIZED_ITERATOR(X, x, Y, y, Z, z, exp)
Definition tensor_macros.h:719
AtomicInt sum
Definition test_atomicint.cc:46
double norm(const T i1)
Definition test_cloud.cc:85
int task(int i)
Definition test_runtime.cpp:4
void e()
Definition test_sig.cc:75
static const double alpha
Definition testcosine.cc:10
const double offset
Definition testfuns.cc:143
constexpr std::size_t NDIM
Definition testgconv.cc:54
double h(const coord_1d &r)
Definition testgconv.cc:175
double g1(const coord_t &r)
Definition testgconv.cc:122
std::size_t axis
Definition testpdiff.cc:59
double source(const coordT &r)
Definition testperiodic.cc:48
#define TENSOR_RESULT_TYPE(L, R)
This macro simplifies access to TensorResultType.
Definition type_data.h:205
#define PROFILE_MEMBER_FUNC(classname)
Definition worldprofile.h:210
#define PROFILE_BLOCK(name)
Definition worldprofile.h:208
int ProcessID
Used to clearly identify process number/rank.
Definition worldtypes.h:43