MADNESS 0.10.1
CCStructures.h
Go to the documentation of this file.
1/*
2 * CCStructures.h
3 *
4 * Created on: Sep 3, 2015
5 * Author: kottmanj
6 */
7
8
9/// File holds all helper structures necessary for the CC_Operator and CC2 class
10#ifndef CCSTRUCTURES_H_
11#define CCSTRUCTURES_H_
12
13#include <madness/mra/mra.h>
17#include <algorithm>
18#include <iomanip>
19#include <iostream>
21
22#include "lowrankfunction.h"
23
24namespace madness {
25
26/// Calculation Types used by CC2
30/// Type of Pairs used by CC_Pair2 class
34
35/// CC2 Singles Potentials
55
56/// Assigns strings to enums for formated output
57std::string
58assign_name(const CCState& input);
59
60/// Assigns enum to string
62assign_calctype(const std::string name);
63
64/// Assigns strings to enums for formated output
65std::string
66assign_name(const CalcType& inp);
67
68/// Assigns strings to enums for formated output
69std::string
70assign_name(const PotentialType& inp);
71
72/// Assigns strings to enums for formated output
73std::string
74assign_name(const FuncType& inp);
75
76/// check memory usage using getrusage
77inline void print_memory_usage(const World& world) {
78 long mem=get_memory_usage();
79 std::string hostname=get_hostname();
80 std::stringstream ss;
81 ss << "memory usage of process "<< world.rank()<< " on "<< hostname<< ": "<< mem/1024/1024<<"MB";
82 std::string msg=ss.str();
83 auto memusage=world.gop.concat0(std::vector<std::string>(1,msg));
84 std::sort(memusage.begin(),memusage.end());
85 if (world.rank()==0) for (const auto& msg : memusage) print(msg);
86}
87
88// Little structure for formated output and to collect warnings
89// much room to improve
91 CCMessenger(World& world) : world(world), output_prec(10), scientific(true), debug(false), os(std::cout) {}
92
96 bool debug;
97
98 void operator()(const std::string& msg) const { output(msg); }
99
100 void debug_output(const std::string& msg) const {
101 if (debug) output(msg);
102 }
103
104 void
105 output(const std::string& msg) const;
106
107 void
108 section(const std::string& msg) const;
109
110 void
111 subsection(const std::string& msg) const;
112
113 void
114 warning(const std::string& msg) const;
115
116 void print_warnings() const {
117 for (const auto& x:warnings) if (world.rank() == 0) std::cout << x << "\n";
118 }
119
120 template<class T>
121 CCMessenger operator<<(const T& t) const {
122 using madness::operators::operator<<;
123 if (world.rank() == 0) os << t;
124 return *this;
125 }
126
127 /// collect all warnings that occur to print out at the end of the job
128 mutable std::vector<std::string> warnings;
129 /// output stream
130 std::ostream& os;
131};
132
133
134/// Timer Structure
135struct CCTimer {
136 /// TDA_TIMER constructor
137 /// @param[in] world the world
138 /// @param[in] msg a string that contains the desired printout when info function is called
140 operation(msg), end_wall(0.0), end_cpu(0.0), time_wall(-1.0),
141 time_cpu(-1.0) {}
142
145 double start_cpu;
146 std::string operation;
147 double end_wall;
148 double end_cpu;
149 double time_wall;
150 double time_cpu;
151
156
157public:
158 /// print out information about the passed time since the CC_TIMER object was created
159 void
160 info(const bool debug = true, const double norm = 12345.6789);
161
165 return *this;
166 }
167
170 end_cpu = cpu_time();
173 return *this;
174 }
175
176 double reset() {
177 stop();
178 double wtime=time_wall;
179 start();
180 return wtime;
181 }
182
183
184 double get_wall_time_diff() const { return end_wall; }
185
186 double get_cpu_time_diff() const { return end_cpu; }
187
188 std::pair<double, double> current_time(bool printout = false) {
189 if (time_wall < 0.0 or time_cpu < 0.0) stop();
190 return std::make_pair(time_wall, time_cpu);
191 }
192
193 void print() {
195 }
196
197 void print() const {
198 print(std::make_pair(time_wall, time_cpu));
199 }
200
201 void print(const std::pair<double, double>& times) const {
202 if (world.rank() == 0) {
203 std::cout << std::setfill(' ') << std::scientific << std::setprecision(2)
204 << "Timer: " << times.first << " (Wall), " << times.second << " (CPU)" << ", (" + operation + ")"
205 << "\n";
206 }
207 }
208};
209
210/// Calculation TDHFParameters for CC2 and TDA calculations
211/// Maybe merge this with calculation_parameters of SCF at some point, or split into TDA and CC
213
217
218 /// copy constructor
219 CCParameters(const CCParameters& other) =default;
220
221 /// ctor reading out the input file
222 CCParameters(World& world, const commandlineparser& parser) {
224 read_input_and_commandline_options(world,parser,"cc2");
226 };
227
228
230 double thresh=1.e-3;
231 double thresh_operators=1.e-6;
232 initialize < std::string > ("calc_type", "mp2", "the calculation type", {"mp2", "mp3", "cc2", "cis", "lrcc2", "cispd", "adc2", "test"});
233 initialize < double > ("lo", 1.e-7, "the finest length scale to be resolved by 6D operators");
234 initialize < double > ("dmin", 1.0, "defines the depth of the special level");
235 initialize < double > ("thresh_6d", thresh, "threshold for the 6D wave function");
236 initialize < double > ("tight_thresh_6d", 0.1*thresh, "tight threshold for the 6D wave function");
237 initialize < double > ("thresh_3d", 0.01*thresh, "threshold for the 3D reference wave function");
238 initialize < double > ("tight_thresh_3d", 0.001*thresh, "tight threshold for the 3D reference wave function");
239 initialize < double > ("thresh_bsh_3d", thresh_operators, "threshold for BSH operators");
240 initialize < double > ("thresh_bsh_6d", thresh_operators, "threshold for BSH operators");
241 initialize < double > ("thresh_poisson", thresh_operators, "threshold for Poisson operators");
242 initialize < double > ("thresh_f12", thresh_operators, "threshold for Poisson operators");
243 initialize < double > ("thresh_Ue", thresh_operators, "ue threshold");
244 initialize < double > ("econv", thresh, "overal convergence threshold ");
245 initialize < double > ("econv_pairs", 0.1*thresh, "convergence threshold for pairs");
246 initialize < double > ("dconv_3d", 0.3*thresh, "convergence for cc singles");
247 initialize < double > ("dconv_6d", 3.0*thresh, "convergence for cc doubles");
248 initialize < std::size_t > ("iter_max", 10, "max iterations");
249 initialize < std::size_t > ("iter_max_3d", 10, "max iterations for singles");
250 initialize < std::size_t > ("iter_max_6d", 10, "max iterations for doubles");
251 initialize < std::pair<int, int>> ("only_pair", {-1, -1}, "compute only a single pair");
252 initialize < bool > ("restart", false, "restart");
253 initialize < bool > ("no_compute", false, "no compute");
254 initialize < bool > ("no_compute_gs", false, "no compute");
255 initialize < bool > ("no_compute_mp2_constantpart", false, "no compute");
256 initialize < bool > ("no_compute_response", false, "no compute");
257 initialize < bool > ("no_compute_mp2", false, "no compute");
258 initialize < bool > ("no_compute_cc2", false, "no compute");
259 initialize < bool > ("no_compute_cispd", false, "no compute");
260 initialize < bool > ("no_compute_lrcc2", false, "no compute");
261 initialize < double > ("corrfac_gamma", 1.0, "exponent for the correlation factor");
262 initialize < std::size_t > ("output_prec", 8, "for formatted output");
263 initialize < bool > ("debug", false, "");
264 initialize < bool > ("plot", false, "");
265 initialize < bool > ("kain", true, "");
266 initialize < std::size_t > ("kain_subspace", 3, "");
267 initialize < long > ("freeze", -1, "number of frozen orbitals: -1: automatic");
268 initialize < bool > ("test", false, "");
269 // choose if Q for the constant part of MP2 and related calculations should be decomposed: GQV or GV - GO12V
270 initialize < bool > ("decompose_Q", true, "always true",{true});
271 // if true the ansatz for the CC2 ground state pairs is |tau_ij> = |u_ij> + Qtf12|titj>, with Qt = Q - |tau><phi|
272 // if false the ansatz is the same with normal Q projector
273 // the response ansatz is the corresponding response of the gs ansatz
274 initialize < bool > ("QtAnsatz", true, "always true",{true});
275 // a vector containing the excitations which shall be optizmized later (with CIS(D) or CC2)
276 initialize < std::vector<size_t>>
277 ("excitations", {}, "vector containing the excitations");
278 }
279
280 void set_derived_values();
281
283 std::string value = get<std::string>("calc_type");
284 if (value == "mp2") return CT_MP2;
285 if (value == "mp3") return CT_MP3;
286 if (value == "cc2") return CT_CC2;
287 if (value == "cis") return CT_LRCCS;
288 if (value == "lrcc2") return CT_LRCC2;
289 if (value == "cispd") return CT_CISPD;
290 if (value == "adc2") return CT_ADC2;
291 if (value == "test") return CT_TEST;
292 MADNESS_EXCEPTION("faulty CalcType", 1);
293 }
294
295 bool response() const {return calc_type()==CT_ADC2 or calc_type()==CT_CISPD or calc_type()==CT_LRCC2 or calc_type()==CT_LRCCS;}
296 double lo() const { return get<double>("lo"); }
297
298 double dmin() const { return get<double>("dmin"); }
299
300 double thresh_3D() const { return get<double>("thresh_3d"); }
301
302 double tight_thresh_3D() const { return get<double>("tight_thresh_3d"); }
303
304 double thresh_6D() const { return get<double>("thresh_6d"); }
305
306 double tight_thresh_6D() const { return get<double>("tight_thresh_6d"); }
307
308 double thresh_bsh_3D() const { return get<double>("thresh_bsh_3d"); }
309
310 double thresh_bsh_6D() const { return get<double>("thresh_bsh_6d"); }
311
312 double thresh_poisson() const { return get<double>("thresh_poisson"); }
313
314 double thresh_f12() const { return get<double>("thresh_f12"); }
315
316 double thresh_Ue() const { return get<double>("thresh_ue"); }
317
318 double econv() const { return get<double>("econv"); }
319
320 double econv_pairs() const { return get<double>("econv_pairs"); }
321
322 double dconv_3D() const { return get<double>("dconv_3d"); }
323
324 double dconv_6D() const { return get<double>("dconv_6d"); }
325
326 std::size_t iter_max() const { return get<std::size_t>("iter_max"); }
327
328 std::size_t iter_max_3D() const { return get<std::size_t>("iter_max_3d"); }
329
330 std::size_t iter_max_6D() const { return get<std::size_t>("iter_max_6d"); }
331
332 std::pair<int, int> only_pair() const { return get<std::pair<int, int>>("only_pair"); }
333
334 bool restart() const { return get<bool>("restart"); }
335
336 bool no_compute() const { return get<bool>("no_compute"); }
337
338 bool no_compute_gs() const { return get<bool>("no_compute_gs"); }
339
340 bool no_compute_mp2_constantpart() const { return get<bool>("no_compute_mp2_constantpart"); }
341
342 bool no_compute_response() const { return get<bool>("no_compute_response"); }
343
344 bool no_compute_mp2() const { return get<bool>("no_compute_mp2"); }
345
346 bool no_compute_cc2() const { return get<bool>("no_compute_cc2"); }
347
348 bool no_compute_cispd() const { return get<bool>("no_compute_cispd"); }
349
350 bool no_compute_lrcc2() const { return get<bool>("no_compute_lrcc2"); }
351
352 bool debug() const { return get<bool>("debug"); }
353
354 bool plot() const { return get<bool>("plot"); }
355
356 bool kain() const { return get<bool>("kain"); }
357
358 bool test() const { return get<bool>("test"); }
359
360 bool decompose_Q() const { return get<bool>("decompose_q"); }
361
362 bool QtAnsatz() const { return get<bool>("qtansatz"); }
363
364 std::size_t output_prec() const { return get<std::size_t>("output_prec"); }
365
366 std::size_t kain_subspace() const { return get<std::size_t>("kain_subspace"); }
367
368 long freeze() const { return get<long>("freeze"); }
369
370 std::vector<std::size_t> excitations() const { return get<std::vector<std::size_t>>("excitations"); }
371
372 double gamma() const {return get<double>("corrfac_gamma");}
373
374 /// print out the parameters
375 void information(World& world) const;
376
377 /// check if parameters are set correct
378 void sanity_check(World& world) const;
379
380 void error(World& world, const std::string& msg) const {
381 if (world.rank() == 0)
382 std::cout << "\n\n\n\n\n!!!!!!!!!\n\nERROR IN CC_PARAMETERS:\n ERROR MESSAGE IS: " << msg
383 << "\n\n\n!!!!!!!!" << std::endl;
384 MADNESS_EXCEPTION("ERROR IN CC_PARAMETERS", 1);
385 }
386
387 size_t warning(World& world, const std::string& msg) const {
388 if (world.rank() == 0) std::cout << "WARNING IN CC_PARAMETERS!: " << msg << std::endl;
389 return 1;
390 }
391
392};
393
395
396 std::vector<std::pair<int, int>> map; ///< maps pair index (i,j) to vector index k
397 PairVectorMap() = default;
398 PairVectorMap(const std::vector<std::pair<int, int>> map1) : map(map1) {}
399
400 static PairVectorMap triangular_map(const int nfreeze, const int nocc) {
401 std::vector<std::pair<int, int>> map; ///< maps pair index (i,j) to vector index k
402 for (int i=nfreeze; i<nocc; ++i) {
403 for (int j=i; j<nocc; ++j) {
404 map.push_back(std::make_pair(i,j));
405 }
406 }
407 return PairVectorMap(map);
408 }
409
410 static PairVectorMap quadratic_map(const int nfreeze, const int nocc) {
411 std::vector<std::pair<int, int>> map; ///< maps pair index (i,j) to vector index k
412 for (int i=nfreeze; i<nocc; ++i) {
413 for (int j=nfreeze; j<nocc; ++j) {
414 map.push_back(std::make_pair(i,j));
415 }
416 }
417 return PairVectorMap(map);
418 }
419
420 void print(const std::string msg="PairVectorMap") const {
421 madness::print(msg);
422 madness::print("vector element <-> pair index");
423 for (size_t i=0; i<map.size(); ++i) {
424 madness::print(i, " <-> ",map[i]);
425 }
426 }
427
428};
429
430/// POD holding all electron pairs with easy access
431/// Similar strucutre than the Pair structure from MP2 but with some additional features (merge at some point)
432/// This structure will also be used for intermediates
433template<typename T>
434struct Pairs {
435
436 typedef std::map<std::pair<int, int>, T> pairmapT;
438
439 /// convert Pairs<T> to another type
440
441 /// opT op takes an object of T and returns the result type
442 template<typename R, typename opT>
443 Pairs<R> convert(const Pairs<T> arg, const opT op) const {
444 Pairs<R> result;
445 for (auto& p : arg.allpairs) {
446 int i=p.first.first;
447 int j=p.first.second;
448 result.insert(i,j,op(p.second));
449 }
450 return result;
451 }
452
453 static Pairs vector2pairs(const std::vector<T>& argument, const PairVectorMap map) {
454 Pairs<T> pairs;
455 for (int i=0; i<argument.size(); ++i) {
456 pairs.insert(map.map[i].first,map.map[i].second,argument[i]);
457 }
458 return pairs;
459 }
460
461 static std::vector<T> pairs2vector(const Pairs<T>& argument, const PairVectorMap map) {
462 std::vector<T> vector;
463 for (size_t i=0; i<argument.allpairs.size(); ++i) {
464 vector.push_back(argument(map.map[i].first,map.map[i].second));
465 }
466 return vector;
467 }
468
469 /// getter
470 const T& operator()(int i, int j) const {
471 return allpairs.at(std::make_pair(i, j));
472 }
473
474 /// getter
475 // at instead of [] operator bc [] inserts new element if nothing is found while at throws out of range error
476 // back to before
477 T& operator()(int i, int j) {
478 // return allpairs.at(std::make_pair(i, j));
479 return allpairs[std::make_pair(i, j)];
480 }
481
482 /// setter
483 /// can NOT replace elements (for this construct new pair map and swap the content)
484 void insert(int i, int j, const T& pair) {
485 std::pair<int, int> key = std::make_pair(i, j);
486 allpairs.insert(std::make_pair(key, pair));
487 }
488
489 /// swap the contant of the pairmap
490 void swap(Pairs<T>& other) {
491 allpairs.swap(other.allpairs);
492 }
493
494 bool empty() const {
495 if (allpairs.size() == 0) return true;
496 else return false;
497 }
498};
499
500/// f12 and g12 intermediates of the form <f1|op|f2> (with op=f12 or op=g12) will be saved using the pair structure
501template <typename T, std::size_t NDIM>
503
504/// Returns the size of an intermediate
505//double
506//size_of(const intermediateT& im);
507/// Returns the size of an intermediate
508template<typename T, std::size_t NDIM>
509double
511 double size = 0.0;
512 for (const auto& tmp : im.allpairs) {
513 size += get_size<T, NDIM>(tmp.second);
514 }
515 return size;
516}
517
518
519
520// structure for CC Vectorfunction
521/// A helper structure which holds a map of functions
523
525
526 CC_vecfunction(const FuncType type_) : type(type_), omega(0.0), current_error(99.9), delta(0.0) {}
527
529 for (size_t i = 0; i < v.size(); i++) {
530 CCFunction<double,3> tmp(v[i], i, type);
531 functions.insert(std::make_pair(i, tmp));
532 }
533 }
534
535 CC_vecfunction(const std::vector<CCFunction<double,3>>& v) : type(UNDEFINED), omega(0.0), current_error(99.9), delta(0.0) {
536 for (size_t i = 0; i < v.size(); i++) {
537 functions.insert(std::make_pair(v[i].i, v[i]));
538 }
539 }
540
542 current_error(99.9), delta(0.0) {
543 for (size_t i = 0; i < v.size(); i++) {
544 CCFunction<double,3> tmp(v[i], i, type);
545 functions.insert(std::make_pair(i, tmp));
546 }
547 }
548
549 CC_vecfunction(const vector_real_function_3d& v, const FuncType& type, const size_t& freeze) : type(type),
550 omega(0.0),
551 current_error(99.9),
552 delta(0.0) {
553 for (size_t i = 0; i < v.size(); i++) {
554 CCFunction<double,3> tmp(v[i], freeze + i, type);
555 functions.insert(std::make_pair(freeze + i, tmp));
556 }
557 }
558
559 CC_vecfunction(const std::vector<CCFunction<double,3>>& v, const FuncType type_)
560 : type(type_), omega(0.0), current_error(99.9), delta(0.0) {
561 for (auto x:v) functions.insert(std::make_pair(x.i, x));
562 }
563
564 /// copy ctor (shallow)
566 : functions(other.functions), type(other.type), omega(other.omega),
568 delta(other.delta), irrep(other.irrep) {
569 }
570
571 /// assignment operator, shallow wrt the functions
572// CC_vecfunction& operator=(const CC_vecfunction& other) = default;
574 if (this == &other) return *this;
575 functions = other.functions;
576 type = other.type;
577 omega = other.omega;
579 delta = other.delta;
580 irrep = other.irrep;
581 return *this;
582 }
583
584
585 /// returns a deep copy (void shallow copy errors)
586 friend CC_vecfunction
587 copy(const CC_vecfunction& other) {
588 CC_vecfunction tmp=other;
589 tmp.functions.clear();
590 for (const auto& x : other.functions) {
591 tmp.functions.insert(std::make_pair(x.first, copy(x.second)));
592 }
593 return tmp;
594 }
595
596 void reconstruct() const {
597 for (auto& x : functions) x.second.function.reconstruct();
598 }
599
600//madness::CC_vecfunction
601//CC_vecfunction::copy() const {
602// std::vector<CCFunction<double,3>> vn;
603// for (auto x : functions) {
604// const CCFunction<double,3> fn(madness::copy(x.second.function), x.second.i, x.second.type);
605// vn.push_back(fn);
606// }
607// CC_vecfunction result(vn, type);
608// result.irrep = irrep;
609// return result;
610//}
611//
612
613 static CC_vecfunction load_restartdata(World& world, std::string filename) {
615 CC_vecfunction tmp;
616 ar & tmp;
617 return tmp;
618 }
619
620 void save_restartdata(World& world, std::string filename) const {
622 ar & *this;
623 }
624
625 template<typename Archive>
626 void serialize(const Archive& ar) {
627 typedef std::vector<std::pair<std::size_t, CCFunction<double,3>>> CC_functionvec;
628
629 auto map2vector = [] (const CC_functionmap& map) {
630 return CC_functionvec(map.begin(), map.end());
631 };
632 auto vector2map = [] (const CC_functionvec& vec) {
633 return CC_functionmap(vec.begin(), vec.end());
634 };
635
636 ar & type & omega & current_error & delta & irrep ;
637 if (ar.is_input_archive) {
638 std::size_t size=0; // set to zero to silence compiler warning
639 ar & size;
640 CC_functionvec tmp(size);
641
642 for (auto& t : tmp) ar & t.first & t.second;
643 functions=vector2map(tmp);
644 } else if (ar.is_output_archive) {
645 auto tmp=map2vector(functions);
646 ar & tmp.size();
647 for (auto& t : tmp) ar & t.first & t.second;
648 }
649 }
650
651 hashT hash() const {
652 hashT hashval = std::hash<FuncType>{}(type);
653 for (const auto& f : functions) hash_combine(hashval, hash_value(f.second.f().get_impl()->id()));
654
655 return hashval;
656 }
657
658 typedef std::map<std::size_t, CCFunction<double,3>> CC_functionmap;
660
662 double omega; /// excitation energy
664 double delta; // Last difference in Energy
665 std::string irrep = "null"; /// excitation irrep (direct product of x function and corresponding orbital)
666
667 std::string
668 name(const int ex) const {
669 return madness::name(type,ex);
670 };
671
672 bool is_converged(const double econv, const double dconv) const {
673 return (current_error<dconv) and (std::fabs(delta)<econv);
674 }
675
676 /// getter
678 return functions.find(i.i)->second;
679 }
680
681 /// getter
682 const CCFunction<double,3>& operator()(const size_t& i) const {
683 return functions.find(i)->second;
684 }
685
686 /// getter
690
691 /// getter
693 return functions[i];
694 }
695
696 /// setter
697 void insert(const size_t& i, const CCFunction<double,3>& f) {
698 functions.insert(std::make_pair(i, f));
699 }
700
701 /// setter
702 void set_functions(const vector_real_function_3d& v, const FuncType& type, const size_t& freeze) {
703 functions.clear();
704 for (size_t i = 0; i < v.size(); i++) {
705 CCFunction<double,3> tmp(v[i], freeze + i, type);
706 functions.insert(std::make_pair(freeze + i, tmp));
707 }
708 }
709
710 /// Returns all the functions of the map as vector
713 for (auto x:functions) tmp.push_back(x.second.function);
714 return tmp;
715 }
716
717 /// Get the size vector (number of functions in the map)
718 size_t size() const {
719 return functions.size();
720 }
721
722 /// Print the memory of which is used by all the functions in the map
723 void
724 print_size(const std::string& msg = "!?not assigned!?") const;
725
726 /// scalar multiplication
727 CC_vecfunction operator*(const double& fac) const {
729 const size_t freeze = functions.cbegin()->first;
730 return CC_vecfunction(vnew, type, freeze);
731 }
732
733 /// scaling (inplace)
734 void scale(const double& factor) {
735 for (auto& ktmp:functions) {
736 ktmp.second.function.scale(factor);
737 }
738 }
739
740 /// operator needed for sort operation (sorted by omega values)
741 bool operator<(const CC_vecfunction& b) const { return omega < b.omega; }
742
743 // plotting
744 void plot(const std::string& msg = "") const {
745 for (auto& ktmp:functions) {
746 ktmp.second.plot(msg);
747 }
748 }
749public:
750 NLOHMANN_DEFINE_TYPE_INTRUSIVE(CC_vecfunction, omega, irrep, current_error)
751
752};
753
754/// Helper Structure that carries out operations on CC_functions
755/// The structure can hold intermediates for g12 and f12 of type : <mo_bra_k|op|type> with type=HOLE,PARTICLE or RESPONSE
756/// some 6D operations are also included
757/// The structure does not know if nuclear correlation facors are used, so the corresponding bra states have to be prepared beforehand
758template<typename T=double, std::size_t NDIM=3>
760public:
761
762 /// parameter class
763 struct Parameters {
765
766 Parameters(const Parameters& other) :
767 thresh_op(other.thresh_op),
768 lo(other.lo),
769 freeze(other.freeze),
770 gamma(other.gamma) {
771 }
772
773 Parameters(const CCParameters& param) : thresh_op(param.thresh_poisson()), lo(param.lo()),
775 gamma(param.gamma()) {};
777 double lo = 1.e-6;
778 int freeze = 0;
779 double gamma = 1.0; /// f12 exponent
780
781 template<typename archiveT>
782 void serialize(archiveT& ar) {
783 ar & thresh_op & lo & freeze & gamma;
784 }
785 };
786
787
788 /// @param[in] world
789 /// @param[in] optype: the operatortype (can be g12_ or f12_)
790 /// @param[in] param: the parameters of the current CC-Calculation (including function and operator thresholds and the exponent for f12)
794
796
797 static inline
798 std::shared_ptr<CCConvolutionOperator> CCConvolutionOperatorPtr(World& world, const OpType type, Parameters param) {
799 return std::shared_ptr<CCConvolutionOperator>(new CCConvolutionOperator(world, type, param));
800 }
801
802protected:
803
805 auto info= SeparatedConvolution<T,NDIM>::combine_OT((*a.get_op()),(*b.get_op()));
807 param.gamma=info.mu;
808 param.thresh_op=info.thresh;
809 param.lo=info.lo;
810 param.freeze=a.parameters.freeze;
811 return CCConvolutionOperator(a.world, info.type, param);
812 }
813
814 friend std::shared_ptr<CCConvolutionOperator> combine(const std::shared_ptr<CCConvolutionOperator>& a,
815 const std::shared_ptr<CCConvolutionOperator>& b) {
816 if (a and (not b)) return a;
817 if ((not a) and b) return b;
818 if ((not a) and (not b)) return nullptr;
819 return std::shared_ptr<CCConvolutionOperator>(new CCConvolutionOperator(combine(*a,*b)));
820 }
821
822public:
823 /// @param[in] f: a 3D function
824 /// @param[out] the convolution op(f), no intermediates are used
826 if (op) return ((*op)(f)).truncate();
827 return f;
828 }
829
830 /// @param[in] bra a CC_vecfunction
831 /// @param[in] ket a CC_function
832 /// @param[out] vector[i] = <bra[i]|op|ket>
833 std::vector<Function<T,NDIM>> operator()(const CC_vecfunction& bra, const CCFunction<T,NDIM>& ket) const {
835 std::vector<Function<T, NDIM>> result;
836 if constexpr (NDIM == 3) {
837 if (bra.type == HOLE) {
838 for (const auto& ktmp: bra.functions) {
839 const CCFunction<T, NDIM>& brai = ktmp.second;
840 const Function<T, NDIM> tmpi = this->operator()(brai, ket);
841 result.push_back(tmpi);
842 }
843 } else {
844 std::vector<Function<T, NDIM>> tmp = mul(world, ket.function, bra.get_vecfunction());
845 result = apply(world, (*op), tmp);
846 truncate(world, result);
847 }
848 } else {
849 MADNESS_EXCEPTION("not implemented", 1);
850 }
851
852 return result;
853 }
854
855 // @param[in] f: a vector of 3D functions
856 // @param[out] the convolution of op with each function, no intermeditates are used
857 std::vector<Function<T,NDIM>> operator()(const std::vector<Function<T,NDIM>>& f) const {
859 return apply<T,T,NDIM,NDIM>(world, (*op), f);
860 }
861
862 // @param[in] bra: a 3D CC_function, if nuclear-correlation factors are used they have to be applied before
863 // @param[in] ket: a 3D CC_function,
864 // @param[in] use_im: default is true, if false then no intermediates are used
865 // @param[out] the convolution <bra|op|ket> = op(bra*ket), if intermediates were calculated before the operator uses them
866 Function<T,NDIM> operator()(const CCFunction<T,NDIM>& bra, const CCFunction<T,NDIM>& ket, const bool use_im = true) const;
867
868 // @param[in] u: a 6D-function
869 // @param[out] the convolution \int g(r,r') u(r,r') dr' (if particle==2) and g(r,r') u(r',r) dr' (if particle==1)
870 // @param[in] particle: specifies on which particle of u the operator will act (particle ==1 or particle==2)
871 Function<T,2*NDIM> operator()(const Function<T,2*NDIM>& u, const size_t particle) const;
872
873 // @param[in] bra: a 3D-CC_function, if nuclear-correlation factors are used they have to be applied before
874 // @param[in] u: a 6D-function
875 // @param[in] particle: specifies on which particle of u the operator will act (particle ==1 or particle==2)
876 // @param[out] the convolution <bra|g12|u>_particle
877 Function<T,NDIM> operator()(const CCFunction<T,NDIM>& bra, const Function<T,2*NDIM>& u, const size_t particle) const;
878
879 /// @param[in] bra: a vector of CC_functions, the type has to be HOLE
880 /// @param[in] ket: a vector of CC_functions, the type can be HOLE,PARTICLE,RESPONSE
881 /// updates intermediates of the type <bra|op|ket>
882 void update_elements(const CC_vecfunction& bra, const CC_vecfunction& ket);
883
884 /// @param[out] prints the name of the operator (convenience) which is g12 or f12 or maybe other things like gf in the future
885 std::string name() const {
886 std::stringstream ss;
887 ss << type();
888 return ss.str();
889 }
890
891 /// @param[in] the type of which intermediates will be deleted
892 /// e.g if(type==HOLE) then all intermediates of type <mo_bra_k|op|HOLE> will be deleted
893 void clear_intermediates(const FuncType& type);
894
895 /// prints out information (operatorname, number of stored intermediates ...)
896 size_t info() const;
897
899 hashT h;
900 hash_combine(h, op.parameters.thresh_op);
901 hash_combine(h, op.parameters.lo);
902 hash_combine(h, op.parameters.freeze);
903 hash_combine(h, op.parameters.gamma);
904 hash_combine(h, int(op.type()));
905 return h;
906 }
907
908 /// sanity check .. doens not do so much
909 void sanity() const { print_intermediate(HOLE); }
910
911 /// @param[in] type: the type of intermediates which will be printed, can be HOLE,PARTICLE or RESPONSE
912 void print_intermediate(const FuncType type) const {
913 if (type == HOLE)
914 for (const auto& tmp:imH.allpairs)
915 tmp.second.print_size("<H" + std::to_string(tmp.first.first) + "|" + name() + "|H" +
916 std::to_string(tmp.first.second) + "> intermediate");
917 else if (type == PARTICLE)
918 for (const auto& tmp:imP.allpairs)
919 tmp.second.print_size("<H" + std::to_string(tmp.first.first) + "|" + name() + "|P" +
920 std::to_string(tmp.first.second) + "> intermediate");
921 else if (type == RESPONSE)
922 for (const auto& tmp:imR.allpairs)
923 tmp.second.print_size("<H" + std::to_string(tmp.first.first) + "|" + name() + "|R" +
924 std::to_string(tmp.first.second) + "> intermediate");
925 }
926
927 /// create a TwoElectronFactory with the operatorkernel
930 factory.set_info(op->info);
931 return factory;
932 }
933
934 OpType type() const { return get_op()->info.type; }
935
937
938 std::shared_ptr<SeparatedConvolution<T,NDIM>> get_op() const {return op;};
939
940private:
941 /// the world
943
944 /// @param[in] optype: can be f12_ or g12_ depending on which operator shall be intitialzied
945 /// @param[in] parameters: parameters (thresholds etc)
946 /// initializes the operators
948
949 std::shared_ptr<SeparatedConvolution<T,NDIM>> op;
953
954 /// @param[in] msg: output message
955 /// the function will throw an MADNESS_EXCEPTION
956 void error(const std::string& msg) const {
957 if (world.rank() == 0)
958 std::cout << "\n\n!!!!ERROR in CCConvolutionOperator " << name() << ": " << msg
959 << "!!!!!\n\n" << std::endl;
960 MADNESS_EXCEPTION(msg.c_str(), 1);
961 }
962public:
963};
964
965template<typename T, std::size_t NDIM>
966std::shared_ptr<CCConvolutionOperator<T,NDIM>> CCConvolutionOperatorPtr(World& world, const OpType type,
968 return std::shared_ptr<CCConvolutionOperator<T,NDIM>>(new CCConvolutionOperator<T,NDIM>(world,type,param));
969}
970
971/// little helper structure which manages the stored singles potentials
977
978 /// check if the intermediate potential exists
980 return potential_exists(type,f.type);
981 }
982
983 /// check if the intermediate potential exists
984 bool potential_exists(const PotentialType& type,const FuncType& ftype) const {
985 bool exists=get_potential(type,ftype,false).size()>0;
986 return exists;
987 }
988
989 /// return a vector of the intermediate potentials
990
991 /// @param[in] ptype: the potential type (POT_SINGLES, POT_S2B, ..)
992 /// @param[in] ftype: the function type (HOLE, PARTICLE, RESPONSE)
994 get_potential(const PotentialType& ptype, const FuncType& ftype, const bool throw_if_empty) const;
995
996 /// fetches the correct stored potential or throws an exception
998 operator()(const CC_vecfunction& f, const PotentialType& type, const bool throw_if_empty) const;
999
1000 /// fetch the potential for a single function
1002 operator()(const CCFunction<double,3>& f, const PotentialType& type, const bool throw_if_empty) const;
1003
1013
1014 /// deltes all stored potentials
1023
1024 /// clears only potentials of the response
1030
1031 /// insert potential
1032 void
1034
1037 records+=cloud.store(world,parameters);
1038 records+=cloud.store(world,current_s2b_potential_ex_);
1039 records+=cloud.store(world,current_s2b_potential_gs_);
1040 records+=cloud.store(world,current_s2c_potential_ex_);
1041 records+=cloud.store(world,current_s2c_potential_gs_);
1042 records+=cloud.store(world,current_singles_potential_ex_);
1043 records+=cloud.store(world,current_singles_potential_gs_);
1044 records+=cloud.store(world,unprojected_cc2_projector_response_);
1045 return records;
1046 }
1047
1058
1060 auto hash_vector_of_functions =[](const vector_real_function_3d& v) {
1061 hashT h;
1062 for (const auto& f : v) {
1063 hash_combine(h, hash_value(f.get_impl()->id()));
1064 }
1065 return h;
1066 };
1067 hashT h;
1068 hash_combine(h, hash_vector_of_functions(ip.current_s2b_potential_ex_));
1069 hash_combine(h, hash_vector_of_functions(ip.current_s2b_potential_gs_));
1070 hash_combine(h, hash_vector_of_functions(ip.current_s2c_potential_ex_));
1071 hash_combine(h, hash_vector_of_functions(ip.current_s2c_potential_gs_));
1072 hash_combine(h, hash_vector_of_functions(ip.current_singles_potential_ex_));
1073 hash_combine(h, hash_vector_of_functions(ip.current_singles_potential_gs_));
1074 hash_combine(h, hash_vector_of_functions(ip.unprojected_cc2_projector_response_));
1075 return h;
1076 }
1077
1079private:
1080 // World& world;
1081 /// whole ground state singles potential without fock-residue
1083 /// whole excited state singles potential without fock-residue
1085 /// s2b_potential for the pure 6D-part of the ground-state (expensive and constant during singles iterations)
1087 /// s2b_potential for the pure 6D-part of the excited-state (expensive and constant during singles iterations)
1089 /// s2c_potential for the pure 6D-part of the ground-state (expensive and constant during singles iterations)
1091 /// s2c_potential for the pure 6D-part of the excited_state (expensive and constant during singles iterations)
1093 /// unprojected S3c + S5c + S2b + S2c potential of CC2 singles
1094 /// for the projector response of the CC2 singles potential
1096
1097 /// structured output
1098 void output(const std::string& msg) const {
1099 if (parameters.debug())
1100 std::cout << "Intermediate Potential Manager: " << msg << "\n";
1101 }
1102};
1103
1104/// POD holding some basic functions and some intermediates for the CC2 calculation
1105
1106/// the class is cloud-serializable and can be used in MacroTasks
1107struct Info {
1108 std::vector<Function<double,3>> mo_ket;
1109 std::vector<Function<double,3>> mo_bra;
1110 std::vector<madness::Vector<double,3>> molecular_coordinates;
1112 std::vector<double> orbital_energies;
1116 std::vector<Function<double,3>> U1;
1117
1120 for (size_t i = parameters.freeze(); i < mo_ket.size(); i++) result.push_back(mo_ket[i]);
1121 return result;
1122 }
1123
1126 for (size_t i = parameters.freeze(); i < mo_bra.size(); i++) result.push_back(mo_bra[i]);
1127 return result;
1128 }
1129
1139
1140 /// customized function to store this to the cloud
1141
1142 /// functions and constant_part can be very large and we want to split them and store them in different records
1145 records+=cloud.store(world,mo_bra);
1146 records+=cloud.store(world,mo_ket);
1147 records+=cloud.store(world,parameters);
1148 records+=cloud.store(world,orbital_energies);
1149 records+=cloud.store(world,fock);
1150 records+=cloud.store(world,intermediate_potentials);
1151 records+=cloud.store(world,R_square);
1152 records+=cloud.store(world,molecular_coordinates);
1153 records+=cloud.store(world,U2);
1154 records+=cloud.store(world,U1);
1155 return records;
1156 }
1157
1158 /// customized function to load this from the cloud
1159
1160 /// functions and constant_part can be very large and we want to split them and store them in different records
1161 /// @param[inout] recordlist: containing the keys of the member variables -> will be reduced by the keys which are used
1162 void cloud_load(World& world, const Cloud& cloud, Recordlist<Cloud::keyT>& recordlist) {
1163 // load bookkeeping stuff in a vector
1164 mo_bra=cloud.forward_load<std::vector<Function<double,3>>>(world,recordlist);
1165 mo_ket=cloud.forward_load<std::vector<Function<double,3>>>(world,recordlist);
1166 parameters=cloud.forward_load<CCParameters>(world,recordlist);
1167 orbital_energies=cloud.forward_load<std::vector<double>>(world,recordlist);
1168 fock=cloud.forward_load<Tensor<double>>(world,recordlist);
1170 R_square=cloud.forward_load<Function<double,3>>(world,recordlist);
1171 molecular_coordinates=cloud.forward_load<std::vector<madness::Vector<double,3>>>(world,recordlist);
1172 U2=cloud.forward_load<Function<double,3>>(world,recordlist);
1173 U1=cloud.forward_load<std::vector<Function<double,3>>>(world,recordlist);
1174 }
1175
1176};
1177
1178
1180public:
1181 CCPair() = default;
1182
1183 CCPair(const size_t ii, const size_t jj, const CCState t, const CalcType c)
1184 : type(t), ctype(c), i(ii), j(jj), bsh_eps(12345.6789) {};
1185
1186 CCPair(const size_t ii, const size_t jj, const CCState t, const CalcType c,
1187 const std::vector<CCPairFunction<double,6>>& f)
1188 : type(t), ctype(c), i(ii), j(jj), functions(f), bsh_eps(12345.6789) {};
1189
1190 CCPair(const CCPair& other) : type(other.type), ctype(other.ctype), i(other.i), j(other.j),
1192 bsh_eps(other.bsh_eps) {};
1193
1196 size_t i;
1197 size_t j;
1198
1199 /// customized function to store this to the cloud
1200
1201 /// functions and constant_part can be very large and we want to split them and store them in different records
1202 /// *NOTE* only the 6d function and the constant part are stored in the cloud, not the 3d functions *NOTE*
1204 // save bookkeeping stuff in a vector
1205 std::vector<unsigned char> v;
1207 bool function_is_assigned=(functions.size()>0 && functions[0].is_assigned());
1208 arout & type & ctype & i & j & bsh_eps & function_is_assigned & constant_part.is_initialized();
1209
1211 records+=cloud.store(world,v);
1212 if (function_is_assigned) records+=cloud.store(world,functions[0]);
1213 if (constant_part.is_initialized()) records+=cloud.store(world,constant_part);
1214 return records;
1215 }
1216
1217 /// customized function to load this from the cloud
1218
1219 /// functions and constant_part can be very large and we want to split them and store them in different records
1220 /// @param[inout] recordlist: containing the keys of the member variables -> will be reduced by the keys which are used
1221 void cloud_load(World& world, const Cloud& cloud, Recordlist<Cloud::keyT>& recordlist) {
1222 // load bookkeeping stuff in a vector
1223 std::vector<unsigned char> v=cloud.forward_load<std::vector<unsigned char>>(world,recordlist);
1225 bool function_is_assigned = false, constant_part_is_initialized=false;
1226 arin & type & ctype & i & j & bsh_eps & function_is_assigned & constant_part_is_initialized;
1227 functions.clear();
1229
1230 if (function_is_assigned) functions.emplace_back(cloud.forward_load<CCPairFunction<double,6>>(world,recordlist));
1231 if (constant_part_is_initialized) constant_part=cloud.forward_load<real_function_6d>(world,recordlist);
1232 }
1233
1234 /// return the world of the function
1235 World& world() const {
1236 MADNESS_CHECK_THROW(function_exists(), "no function assigned in CCPair::world()");
1237 return function().world();
1238 }
1239
1240 /// check if the pair has a function assigned
1241 bool function_exists() const {
1242 return (functions.size()>0 and functions[0].is_assigned() and functions[0].is_pure());
1243 }
1244
1245 /// gives back the pure 6D part of the pair function
1247 MADNESS_CHECK_THROW(not functions.empty(), "no function assigned in CCPair::function()");
1248 MADNESS_CHECK_THROW(functions[0].is_pure(),"function is not pure in CCPair::function()");
1249 return functions[0].get_function();
1250 }
1251
1252 /// updates the pure 6D part of the pair function
1254 // print("updating u(",i,j,")");
1255 CCPairFunction tmp(u);
1256 if (functions.size() == 0) functions.push_back(tmp);
1257 else { //(functions.size() > 1) {
1258 MADNESS_CHECK_THROW(functions[0].is_pure(),"function is not pure in CCPair::update_u()");
1259 functions[0]=tmp;
1260 }
1261 }
1262
1263 template<typename Archive>
1264 void serialize(const Archive& ar) {
1265 size_t f_size = functions.size();
1266 bool fexist = (f_size > 0) && (functions[0].get_function().is_initialized());
1267 bool cexist = constant_part.is_initialized();
1268 ar & type & ctype & i & j & bsh_eps & fexist & cexist & f_size;
1269 if constexpr (Archive::is_input_archive) {
1270 if (fexist) {
1272 ar & func;
1274 functions.push_back(f1);
1275 }
1276 } else {
1277 if (fexist) ar & functions[0].get_function();
1278 }
1279 if (cexist) ar & constant_part;
1280 }
1281
1282 /// reconstruct constant part and all functions
1283 void reconstruct() const {
1285 for (auto& f : functions) {
1286 if (f.is_assigned() and f.is_pure()) f.get_function().reconstruct();
1287 }
1288 }
1289
1290 bool load_pair(World& world, const bool verbose=false) {
1291 std::string fname=this->name();
1292 if (verbose and world.rank()==0) print("loading pair from file", fname);
1294 if (exists) {
1296 ar & *this;
1297 if (functions[0].get_function().is_initialized()) functions[0].get_function().set_thresh(FunctionDefaults<6>::get_thresh());
1299 }
1300 return exists;
1301 }
1302
1303 void store_pair(World& world, const bool verbose=false) {
1304 std::string fname =this->name();
1305 if (verbose and world.rank()==0) print("loading pair from file", fname);
1306 this->reconstruct();
1308 ar & *this;
1309 }
1310
1311 hashT hash() const {
1312 hashT hash_i = std::hash<std::size_t>{}(i);
1313 hash_combine(hash_i, std::hash<std::size_t>{}(j));
1316 }
1317 return hash_i;
1318 }
1319
1320 /// the functions which belong to the pair
1321 std::vector<CCPairFunction<double,6>> functions;
1322
1323 /// the constant part
1325
1326 /// Energy for the BSH Operator
1327 /// Ground State: e_i + e_j
1328 /// Excited State: e_i + e_j + omega
1329 /// default to positive value to make sure this is set somewhere
1330 double bsh_eps=1.0;
1331
1332 /// return the base name like "MP2_pair_u" or "CC2_pair_x"
1333 std::string basename() const {
1334 std::string name = "???";
1335 if (type == GROUND_STATE) name = assign_name(ctype) + "_pair_u";
1336 if (type == EXCITED_STATE) name = assign_name(ctype) + "_pair_x";
1337 return name;
1338
1339 }
1340 std::string name() const {
1341 return basename() +"_" + stringify(i) + stringify(j);
1342 }
1343
1344 void
1345 info() const;
1346
1347};
1348
1349/// build an MP2 or CC2 or LRCC2 etc pair, possibly including the lo-rank parts
1351public:
1353
1354 /// provide ground-state singles, needed for CC2 and LRCC2 wave function ansatz
1356 gs_singles = gs;
1357 return *this;
1358 }
1359
1360 /// provide excited state singles, needed for CC2 and LRCC2 wave function ansatz
1362 ex_singles = ex;
1363 return *this;
1364 }
1365
1367 ctype = type;
1368 return *this;
1369 }
1370
1371 /// make a CCPair without the 6d function and some bookkeeping information
1372 CCPair make_bare_pair(const int i, const int j) const;
1373
1374 /// make a CCPair with the 6d function only and some bookkeeping information
1375 CCPair make_bare_pair_from_file(const int i, const int j) const;
1376
1377 /// make a CCPair
1378 CCPair make_pair(const int i, const int j, const std::vector<CCPairFunction<double,6>>& u) const;
1379
1380 inline static CCState cc_state(const CalcType& type) {
1381 if (type==CT_MP2 or type==CT_CC2 or type==CT_MP3) return GROUND_STATE;
1382 else if (type==CT_LRCC2 or type==CT_ADC2 or type==CT_CISPD) return EXCITED_STATE;
1383 else {
1384 MADNESS_EXCEPTION("unknown cc-state",1);
1385 }
1386 }
1387
1388 /// make a CCPair with the 6d function only and some bookkeeping information
1390 Pairs<CCPair> pairs;
1391 for (size_t i = info.parameters.freeze(); i < info.mo_bra.size(); i++) {
1392 for (size_t j = info.parameters.freeze(); j < info.mo_ket.size(); j++) {
1393 pairs.insert(i,j,make_bare_pair(i, j));
1394 }
1395 }
1396 return pairs;
1397 }
1398
1399 /// complete the given pair with the low-rank parts
1400
1401 /// will use pair's ctype, while builder's ctype is ignored
1403
1404
1405 /// Function to load a function from disk
1406
1407 /// @param[in] name of the file in which the function was stored
1408 /// @param do_print
1409 /// @return the function, possibly not initialized if not found on disk
1410 template <typename T, size_t NDIM>
1411 Function<T,NDIM> load_function(const std::string name, bool do_print) const {
1413 bool exists = archive::ParallelInputArchive<
1415 if (exists) {
1416 if ((world.rank() == 0) and do_print) print("loading function", name);
1418 ar & f;
1419 if (do_print) f.print_size(name);
1420 if (f.is_compressed()) {
1421 if (world.rank()==0 and do_print) print("function is compressed -- reconstructing");
1422 f.change_tree_state(reconstructed);
1423 if (do_print) f.print_size(name+" reconstructed");
1424 save(f, name);
1425 }
1427 f.truncate();
1428 f.print_size(name);
1429 } else {
1430 if ((world.rank()==0) and do_print) print("could not find function",name);
1431 }
1432 return f;
1433 }
1434
1436 const Info& info;
1439
1440};
1441
1442
1443/// print accumulated size of all functions
1444struct CCSize {
1445 double size_local=0;
1446
1447 CCSize() = default;
1448
1449 template<typename T, std::size_t NDIM>
1450 void add_helper(const std::vector<Function<T,NDIM>>& v) {
1451 if (v.size()>0) size_local+=get_size_local(v.front().world(),v);
1452 }
1453
1454 void add_helper(const std::vector<CCPair>& vp) {
1455 if (vp.empty()) return;
1456 for (const auto& p : vp) {
1457 size_local+=get_size(p.constant_part);
1458 if (p.function_exists()) size_local+=get_size_local(p.function());
1459 }
1460 }
1461
1462 /// variadic template parameters to add the size of all functions and pairs
1463 template<typename... Args>
1464 void add(const Args&... args) {
1465 (add_helper(args), ...);
1466 }
1467
1468 void print(World& world, const std::string msg="") const {
1469 double size_global=size_local;
1470 world.gop.sum(size_global);
1471 if (msg.size()>0 and world.rank()==0) madness::print(msg);
1472 world.gop.fence();
1473 madness::print("size of all functions on rank",world.rank(),size_local);
1474 world.gop.fence();
1475 if (world.rank()==0) madness::print("total size of all functions",size_global);
1476
1477 }
1478};
1479
1480
1482
1484 public:
1486
1487 partitionT do_partitioning(const std::size_t& vsize1, const std::size_t& vsize2,
1488 const std::string policy) const override {
1489 partitionT p;
1490 for (size_t i = 0; i < vsize1; i++) {
1491 Batch batch(Batch_1D(i,i+1), Batch_1D(i,i+1));
1492 p.push_back(std::make_pair(batch,1.0));
1493 }
1494 return p;
1495 }
1496 };
1497
1498public:
1500
1501 // typedef std::tuple<const std::vector<CCPair>&, const std::vector<Function<double,3>>&,
1502 // const std::vector<Function<double,3>>&, const CCParameters&, const Function<double,3>&,
1503 // const std::vector<Function<double,3>>&, const std::vector<std::string>& > argtupleT;
1504 typedef std::tuple<const std::vector<CCPair>&, const madness::Info&, const std::vector<std::string>& > argtupleT;
1505
1506 using resultT = std::vector<real_function_6d>;
1507
1508 resultT allocator(World& world, const argtupleT& argtuple) const {
1509 std::size_t n = std::get<0>(argtuple).size();
1510 resultT result = zero_functions_auto_tree_state<double, 6>(world, n);
1511 return result;
1512 }
1513
1514// resultT operator() (const std::vector<CCPair>& pair, const std::vector<Function<double,3>>& mo_ket,
1515// const std::vector<Function<double,3>>& mo_bra, const CCParameters& parameters,
1516// const Function<double,3>& Rsquare, const std::vector<Function<double,3>>& U1,
1517// const std::vector<std::string>& argument) const;
1518 resultT operator() (const std::vector<CCPair>& pair, const Info& info, const std::vector<std::string>& argument) const;
1519};
1520
1521/// compute the "constant" part of MP2, CC2, or LR-CC2
1522///
1523/// the constant part is
1524/// result = G [F,f] |ij> for MP2
1525/// result = G [F,f] |t_i t_j> for CC2
1526/// result = G [F,f] |t_i x_j> + |x_i t_j> for LR-CC2
1528
1530 public:
1532
1533 partitionT do_partitioning(const std::size_t& vsize1, const std::size_t& vsize2,
1534 const std::string policy) const override {
1535 partitionT p;
1536 for (size_t i = 0; i < vsize1; i++) {
1537 Batch batch(Batch_1D(i,i+1), Batch_1D(i,i+1));
1538 p.push_back(std::make_pair(batch,1.0));
1539 }
1540 return p;
1541 }
1542 };
1543
1544public:
1547 name="ConstantPart";
1548 }
1549
1550 // typedef std::tuple<const std::vector<CCPair>&, const std::vector<Function<double,3>>&,
1551 // const std::vector<Function<double,3>>&, const CCParameters&, const Function<double,3>&,
1552 // const std::vector<Function<double,3>>&, const std::vector<std::string>& > argtupleT;
1553 typedef std::tuple<const std::vector<CCPair>&,
1554 const std::vector<Function<double,3>>&, const std::vector<Function<double,3>>&,
1556
1557 using resultT = std::vector<real_function_6d>;
1558
1559 resultT allocator(World& world, const argtupleT& argtuple) const {
1560 std::size_t n = std::get<0>(argtuple).size();
1561 resultT result = zero_functions_auto_tree_state<double, 6>(world, n);
1562 return result;
1563 }
1564 resultT operator() (const std::vector<CCPair>& pair,
1565 const std::vector<Function<double,3>>& gs_singles,
1566 const std::vector<Function<double,3>>& ex_singles,
1567 const Info& info) const;
1568};
1569
1571
1573 public :
1577
1578 partitionT do_partitioning(const std::size_t& vsize1, const std::size_t& vsize2,
1579 const std::string policy) const override {
1580 partitionT p;
1581 for (size_t i = 0; i < vsize1; i++) {
1582 Batch batch(Batch_1D(i, i+1), Batch_1D(i, i+1), Batch_1D(i,i+1));
1583 p.push_back(std::make_pair(batch, 1.0));
1584 }
1585 return p;
1586 }
1587 };
1588public:
1591 name="MP2UpdatePair";
1592 }
1593
1594 // typedef std::tuple<const std::vector<CCPair>&, const std::vector<real_function_6d>&, const CCParameters&,
1595 // const std::vector< madness::Vector<double,3> >&,
1596 // const std::vector<Function<double,3>>&, const std::vector<Function<double,3>>&,
1597 // const std::vector<Function<double,3>>&, const Function<double,3>&> argtupleT;
1598 typedef std::tuple<const std::vector<CCPair>&, const std::vector<real_function_6d>&,
1599 const std::vector<madness::Vector<double,3>>&, const Info& > argtupleT;
1600
1601 using resultT = std::vector<real_function_6d>;
1602
1603 resultT allocator(World& world, const argtupleT& argtuple) const {
1604 std::size_t n = std::get<0>(argtuple).size();
1605 resultT result = zero_functions_auto_tree_state<double, 6>(world, n);
1606 return result;
1607 }
1608
1609// resultT operator() (const std::vector<CCPair>& pair, const std::vector<real_function_6d>& mp2_coupling, const CCParameters& parameters,
1610// const std::vector< madness::Vector<double,3> >& all_coords_vec,
1611// const std::vector<Function<double,3>>& mo_ket, const std::vector<Function<double,3>>& mo_bra,
1612// const std::vector<Function<double,3>>& U1, const Function<double,3>& U2) const;
1613 resultT operator() (const std::vector<CCPair>& pair, const std::vector<real_function_6d>& mp2_coupling,
1614 const std::vector< madness::Vector<double,3> >& all_coords_vec, const Info& info) const;
1615};
1616
1617
1619
1621 public :
1623
1624 partitionT do_partitioning(const std::size_t& vsize1, const std::size_t& vsize2,
1625 const std::string policy) const override {
1626 partitionT p;
1627 for (size_t i = 0; i < vsize1; i++) {
1628 Batch batch(Batch_1D(i, i+1), Batch_1D(i, i+1), Batch_1D(i,i+1));
1629 p.push_back(std::make_pair(batch,1.0));
1630 }
1631 return p;
1632 }
1633 };
1634public:
1637 name="IteratePair";
1638 }
1639
1640 typedef std::tuple<
1641 const std::vector<CCPair>&, // pair
1642 const std::vector<real_function_6d>&, // local coupling
1643 const CC_vecfunction&, // gs singles
1644 const CC_vecfunction&, // ex singles
1645 const Info&,
1646 const std::size_t&
1648
1649 using resultT = std::vector<real_function_6d>;
1650
1651 resultT allocator(World& world, const argtupleT& argtuple) const {
1652 std::size_t n = std::get<0>(argtuple).size();
1653 resultT result = zero_functions_auto_tree_state<double, 6>(world, n);
1654 return result;
1655 }
1656
1657 /// iterate a given pair of the MP2, CC2 or LRCC2 calculation
1658
1659 /// will *NOT* compute the local coupling,
1660 /// will apply the Fock operators (J-K+V)|pair> and use
1661 /// the (excited) singles vectors to update the pair
1662 /// @param[in] pair: the pair which will be updated
1663 /// @param[in] gs_singles: the ground state singles, may be dummy for MP2
1664 /// @param[in] ex_singles: the excited state singles, may be dummy for MP2, CC2
1665 /// @param[in] all_coords_vec: the coordinates of the atoms
1666 /// @param[in] info: the info structure
1667 /// @param[in] maxiter: the maximal number of iterations
1668 resultT operator() (const std::vector<CCPair>& pair,
1669 const std::vector<real_function_6d>& local_coupling,
1670 const CC_vecfunction& gs_singles,
1671 const CC_vecfunction& ex_singles,
1672 const Info& info,
1673 const std::size_t& maxiter) const;
1674};
1675
1676
1678public:
1679 std::string basename="SinglesPotentialEx";
1681 name="SinglesPotentialEx";
1682 partitioner->max_batch_size=2;
1683 partitioner->min_batch_size=2;
1684 }
1685
1686 typedef std::tuple<
1687 const std::vector<int>&, // result_index,
1688 const CC_vecfunction&, // singles_gs,
1689 const std::vector<CCPair>&, // doubles_gs,
1690 const CC_vecfunction&, // singles_ex,
1691 const std::vector<CCPair>&, // doubles_ex,
1692 const int&, // name,
1693 const Info& // info
1695
1696 using resultT = std::tuple<std::vector<real_function_3d>,std::vector<real_function_3d>>;
1697
1698 resultT allocator(World& world, const argtupleT& argtuple) const {
1699 std::size_t n = std::get<0>(argtuple).size();
1700 std::vector<real_function_3d> result = zero_functions_auto_tree_state<double, 3>(world, n);
1701 std::vector<real_function_3d> intermediate = zero_functions_auto_tree_state<double, 3>(world, n);
1702 const_cast<std::string&>(name) =basename+"_"+assign_name(PotentialType(std::get<5>(argtuple)));
1703 return std::make_tuple(result,intermediate);
1704 }
1705
1706 resultT operator() (const std::vector<int>& result_index,
1707 const CC_vecfunction& singles_gs,
1708 const std::vector<CCPair>& doubles_gs,
1709 const CC_vecfunction& singles_ex,
1710 const std::vector<CCPair>& doubles_ex,
1711 const int& name,
1712 const Info& info);
1713};
1714
1716public:
1717 std::string basename="SinglesPotentialGs";
1719 name="SinglesPotentialGs";
1720 }
1721
1722 typedef std::tuple<
1723 const std::vector<int>&, // result_index,
1724 const CC_vecfunction&, // singles_gs,
1725 const std::vector<CCPair>&, // doubles_gs,
1726 const int&, // name,
1727 const Info& // info
1729
1730 /// first vector is the potential, second is an intermediate (if applicable, e.g. for s2b and s2c potentials)
1731 using resultT = std::tuple<std::vector<real_function_3d>,std::vector<real_function_3d>>;
1732
1733 /// allocate the result and set the name of this task
1734 resultT allocator(World& world, const argtupleT& argtuple) const {
1735 std::size_t n = std::get<0>(argtuple).size();
1736 std::vector<real_function_3d> result = zero_functions_auto_tree_state<double, 3>(world, n);
1737 std::vector<real_function_3d> intermediate = zero_functions_auto_tree_state<double, 3>(world, n);
1738 const_cast<std::string&>(name) =basename+"_"+assign_name(PotentialType(std::get<3>(argtuple)));
1739 return std::make_tuple(result,intermediate);
1740 }
1741
1742 resultT operator() (const std::vector<int>& result_index,
1743 const CC_vecfunction& singles_gs,
1744 const std::vector<CCPair>& doubles_gs,
1745 const int& name,
1746 const Info& info);
1747};
1748
1749
1751public:
1752 std::string basename="CorrelationEnergy";
1754 name="CorrelationEnergy";
1755 }
1756
1757 typedef std::tuple<
1758 const std::vector<CCPair>&,
1759 const CC_vecfunction&,
1760 const Info&
1762
1763 /// first vector is the potential, second is an intermediate (if applicable, e.g. for s2b and s2c potentials)
1764 typedef std::vector<ScalarResult<double>> resultT;
1765
1766
1767 /// allocate the result and set the name of this task
1768 resultT allocator(World &world, const argtupleT &argtuple) const {
1769 std::size_t n = std::get<0>(argtuple).size();
1770 return scalar_result_vector<double>(world,n);
1771 }
1772
1773 resultT operator() (const std::vector<CCPair>& pairs,
1774 const CC_vecfunction& singles_gs,
1775 const Info& info) const;
1776};
1777
1778}//namespace madness
1779
1780#endif /* CCSTRUCTURES_H_ */
double potential(const coord_3d &r)
Definition 3dharmonic.cc:132
Definition macrotaskpartitioner.h:55
a batch consists of a 2D-input batch and a 1D-output batch: K-batch <- (I-batch, J-batch)
Definition macrotaskpartitioner.h:124
Definition CCStructures.h:759
intermediateT< T, NDIM > imH
Definition CCStructures.h:950
CCConvolutionOperator(const CCConvolutionOperator &other)=default
friend hashT hash_value(CCConvolutionOperator< T, NDIM > &op)
Definition CCStructures.h:898
static std::shared_ptr< CCConvolutionOperator > CCConvolutionOperatorPtr(World &world, const OpType type, Parameters param)
Definition CCStructures.h:798
Function< T, NDIM > operator()(const Function< T, NDIM > &f) const
Definition CCStructures.h:825
SeparatedConvolution< T, NDIM > * init_op(const OpType &type, const Parameters &parameters) const
Definition CCStructures.cc:370
size_t info() const
prints out information (operatorname, number of stored intermediates ...)
Definition CCStructures.cc:352
std::shared_ptr< SeparatedConvolution< T, NDIM > > op
Definition CCStructures.h:949
std::vector< Function< T, NDIM > > operator()(const std::vector< Function< T, NDIM > > &f) const
Definition CCStructures.h:857
OpType type() const
Definition CCStructures.h:934
void clear_intermediates(const FuncType &type)
Definition CCStructures.cc:330
World & world
the world
Definition CCStructures.h:942
void sanity() const
sanity check .. doens not do so much
Definition CCStructures.h:909
std::string name() const
Definition CCStructures.h:885
friend std::shared_ptr< CCConvolutionOperator > combine(const std::shared_ptr< CCConvolutionOperator > &a, const std::shared_ptr< CCConvolutionOperator > &b)
Definition CCStructures.h:814
void update_elements(const CC_vecfunction &bra, const CC_vecfunction &ket)
Definition CCStructures.cc:298
intermediateT< T, NDIM > imP
Definition CCStructures.h:951
void error(const std::string &msg) const
Definition CCStructures.h:956
const Parameters parameters
Definition CCStructures.h:936
CCConvolutionOperator(World &world, const OpType type, Parameters param)
Definition CCStructures.h:791
std::vector< Function< T, NDIM > > operator()(const CC_vecfunction &bra, const CCFunction< T, NDIM > &ket) const
Definition CCStructures.h:833
std::shared_ptr< SeparatedConvolution< T, NDIM > > get_op() const
Definition CCStructures.h:938
void print_intermediate(const FuncType type) const
Definition CCStructures.h:912
intermediateT< T, NDIM > imR
Definition CCStructures.h:952
TwoElectronFactory< T, 2 *NDIM > get_kernel() const
create a TwoElectronFactory with the operatorkernel
Definition CCStructures.h:928
friend CCConvolutionOperator combine(const CCConvolutionOperator &a, const CCConvolutionOperator &b)
Definition CCStructures.h:804
structure for a CC Function 3D which holds an index and a type
Definition ccpairfunction.h:45
Function< T, NDIM > function
Definition ccpairfunction.h:70
size_t i
Definition ccpairfunction.h:78
build an MP2 or CC2 or LRCC2 etc pair, possibly including the lo-rank parts
Definition CCStructures.h:1350
CCPairBuilder & set_ex_singles(const CC_vecfunction &ex)
provide excited state singles, needed for CC2 and LRCC2 wave function ansatz
Definition CCStructures.h:1361
CCPairBuilder(World &world, const Info &info)
Definition CCStructures.h:1352
CC_vecfunction gs_singles
Definition CCStructures.h:1437
const Info & info
Definition CCStructures.h:1436
CCPair make_bare_pair(const int i, const int j) const
make a CCPair without the 6d function and some bookkeeping information
Definition CCStructures.cc:506
CCPairBuilder & set_gs_singles(const CC_vecfunction &gs)
provide ground-state singles, needed for CC2 and LRCC2 wave function ansatz
Definition CCStructures.h:1355
static CCState cc_state(const CalcType &type)
Definition CCStructures.h:1380
CCPair make_bare_pair_from_file(const int i, const int j) const
make a CCPair with the 6d function only and some bookkeeping information
Definition CCStructures.cc:529
World & world
Definition CCStructures.h:1435
Function< T, NDIM > load_function(const std::string name, bool do_print) const
Function to load a function from disk.
Definition CCStructures.h:1411
CCPair make_pair(const int i, const int j, const std::vector< CCPairFunction< double, 6 > > &u) const
make a CCPair
Definition CCStructures.cc:520
CalcType ctype
Definition CCStructures.h:1438
CC_vecfunction ex_singles
Definition CCStructures.h:1437
CCPairBuilder & set_ctype(const CalcType &type)
Definition CCStructures.h:1366
CCPair complete_pair_with_low_rank_parts(const CCPair &pair) const
complete the given pair with the low-rank parts
Definition CCStructures.cc:545
Pairs< CCPair > make_all_bare_pairs() const
make a CCPair with the 6d function only and some bookkeeping information
Definition CCStructures.h:1389
a 6D function, either in full or low rank form, possibly including an 2-particle function
Definition ccpairfunction.h:373
Definition CCStructures.h:1179
void reconstruct() const
reconstruct constant part and all functions
Definition CCStructures.h:1283
hashT hash() const
Definition CCStructures.h:1311
void info() const
Definition CCStructures.cc:84
std::string basename() const
return the base name like "MP2_pair_u" or "CC2_pair_x"
Definition CCStructures.h:1333
CCPair(const CCPair &other)
Definition CCStructures.h:1190
World & world() const
return the world of the function
Definition CCStructures.h:1235
void store_pair(World &world, const bool verbose=false)
Definition CCStructures.h:1303
Recordlist< Cloud::keyT > cloud_store(World &world, Cloud &cloud) const
customized function to store this to the cloud
Definition CCStructures.h:1203
bool function_exists() const
check if the pair has a function assigned
Definition CCStructures.h:1241
std::string name() const
Definition CCStructures.h:1340
CCPair(const size_t ii, const size_t jj, const CCState t, const CalcType c, const std::vector< CCPairFunction< double, 6 > > &f)
Definition CCStructures.h:1186
size_t i
Definition CCStructures.h:1196
bool load_pair(World &world, const bool verbose=false)
Definition CCStructures.h:1290
real_function_6d function() const
gives back the pure 6D part of the pair function
Definition CCStructures.h:1246
real_function_6d constant_part
the constant part
Definition CCStructures.h:1324
std::vector< CCPairFunction< double, 6 > > functions
the functions which belong to the pair
Definition CCStructures.h:1321
CCPair(const size_t ii, const size_t jj, const CCState t, const CalcType c)
Definition CCStructures.h:1183
void update_u(const real_function_6d &u)
updates the pure 6D part of the pair function
Definition CCStructures.h:1253
size_t j
Definition CCStructures.h:1197
CCState type
Definition CCStructures.h:1194
CCPair()=default
double bsh_eps
Definition CCStructures.h:1330
void serialize(const Archive &ar)
Definition CCStructures.h:1264
CalcType ctype
Definition CCStructures.h:1195
void cloud_load(World &world, const Cloud &cloud, Recordlist< Cloud::keyT > &recordlist)
customized function to load this from the cloud
Definition CCStructures.h:1221
cloud class
Definition cloud.h:147
recordlistT store(madness::World &world, const T &source)
Definition cloud.h:316
T forward_load(madness::World &world, recordlistT &recordlist) const
load a single object from the cloud, recordlist is consumed while loading elements
Definition cloud.h:298
FunctionDefaults holds default paramaters as static class members.
Definition funcdefaults.h:100
static const double & get_thresh()
Returns the default threshold.
Definition funcdefaults.h:176
A multiresolution adaptive numerical function.
Definition mra.h:139
World & world() const
Returns the world.
Definition mra.h:688
void set_thresh(double value, bool fence=true)
Sets the value of the truncation threshold. Optional global fence.
Definition mra.h:617
const std::shared_ptr< FunctionImpl< T, NDIM > > & get_impl() const
Returns a shared-pointer to the implementation.
Definition mra.h:654
const Function< T, NDIM > & reconstruct(bool fence=true) const
Reconstructs the function, transforming into scaling function basis. Possible non-blocking comm.
Definition mra.h:817
void clear(bool fence=true)
Clears the function as if constructed uninitialized. Optional fence.
Definition mra.h:889
bool is_initialized() const
Returns true if the function is initialized.
Definition mra.h:167
Definition CCStructures.h:1750
resultT operator()(const std::vector< CCPair > &pairs, const CC_vecfunction &singles_gs, const Info &info) const
Definition CCStructures.cc:748
std::tuple< const std::vector< CCPair > &, const CC_vecfunction &, const Info & > argtupleT
Definition CCStructures.h:1761
MacroTaskComputeCorrelationEnergy()
Definition CCStructures.h:1753
resultT allocator(World &world, const argtupleT &argtuple) const
allocate the result and set the name of this task
Definition CCStructures.h:1768
std::vector< ScalarResult< double > > resultT
first vector is the potential, second is an intermediate (if applicable, e.g. for s2b and s2c potenti...
Definition CCStructures.h:1764
std::string basename
Definition CCStructures.h:1752
partitionT do_partitioning(const std::size_t &vsize1, const std::size_t &vsize2, const std::string policy) const override
override this if you want your own partitioning
Definition CCStructures.h:1533
ConstantPartPartitioner()
Definition CCStructures.h:1531
Definition CCStructures.h:1527
std::vector< real_function_6d > resultT
Definition CCStructures.h:1557
MacroTaskConstantPart()
Definition CCStructures.h:1545
std::tuple< const std::vector< CCPair > &, const std::vector< Function< double, 3 > > &, const std::vector< Function< double, 3 > > &, const madness::Info & > argtupleT
Definition CCStructures.h:1555
resultT allocator(World &world, const argtupleT &argtuple) const
Definition CCStructures.h:1559
resultT operator()(const std::vector< CCPair > &pair, const std::vector< Function< double, 3 > > &gs_singles, const std::vector< Function< double, 3 > > &ex_singles, const Info &info) const
Definition CCStructures.cc:616
partitionT do_partitioning(const std::size_t &vsize1, const std::size_t &vsize2, const std::string policy) const override
override this if you want your own partitioning
Definition CCStructures.h:1624
Definition CCStructures.h:1618
std::tuple< const std::vector< CCPair > &, const std::vector< real_function_6d > &, const CC_vecfunction &, const CC_vecfunction &, const Info &, const std::size_t & > argtupleT
Definition CCStructures.h:1647
resultT operator()(const std::vector< CCPair > &pair, const std::vector< real_function_6d > &local_coupling, const CC_vecfunction &gs_singles, const CC_vecfunction &ex_singles, const Info &info, const std::size_t &maxiter) const
iterate a given pair of the MP2, CC2 or LRCC2 calculation
Definition CCStructures.cc:653
MacroTaskIteratePair()
Definition CCStructures.h:1635
resultT allocator(World &world, const argtupleT &argtuple) const
Definition CCStructures.h:1651
std::vector< real_function_6d > resultT
Definition CCStructures.h:1649
partitionT do_partitioning(const std::size_t &vsize1, const std::size_t &vsize2, const std::string policy) const override
override this if you want your own partitioning
Definition CCStructures.h:1487
Definition CCStructures.h:1481
resultT operator()(const std::vector< CCPair > &pair, const Info &info, const std::vector< std::string > &argument) const
Definition CCStructures.cc:604
MacroTaskMp2ConstantPart()
Definition CCStructures.h:1499
std::tuple< const std::vector< CCPair > &, const madness::Info &, const std::vector< std::string > & > argtupleT
Definition CCStructures.h:1504
std::vector< real_function_6d > resultT
Definition CCStructures.h:1506
resultT allocator(World &world, const argtupleT &argtuple) const
Definition CCStructures.h:1508
UpdatePairPartitioner()
Definition CCStructures.h:1574
partitionT do_partitioning(const std::size_t &vsize1, const std::size_t &vsize2, const std::string policy) const override
override this if you want your own partitioning
Definition CCStructures.h:1578
Definition CCStructures.h:1570
MacroTaskMp2UpdatePair()
Definition CCStructures.h:1589
resultT allocator(World &world, const argtupleT &argtuple) const
Definition CCStructures.h:1603
std::vector< real_function_6d > resultT
Definition CCStructures.h:1601
std::tuple< const std::vector< CCPair > &, const std::vector< real_function_6d > &, const std::vector< madness::Vector< double, 3 > > &, const Info & > argtupleT
Definition CCStructures.h:1599
resultT operator()(const std::vector< CCPair > &pair, const std::vector< real_function_6d > &mp2_coupling, const std::vector< madness::Vector< double, 3 > > &all_coords_vec, const Info &info) const
Definition CCStructures.cc:635
Definition macrotaskq.h:978
Batch batch
Definition macrotaskq.h:980
std::shared_ptr< MacroTaskPartitioner > partitioner
Definition macrotaskq.h:982
std::string name
Definition macrotaskq.h:981
partition one (two) vectors into 1D (2D) batches.
Definition macrotaskpartitioner.h:182
std::string policy
how to partition the batches
Definition macrotaskpartitioner.h:190
std::list< std::pair< Batch, double > > partitionT
Definition macrotaskpartitioner.h:186
MacroTaskPartitioner & set_dimension(const std::size_t &n)
Definition macrotaskpartitioner.h:205
Definition CCStructures.h:1677
std::tuple< std::vector< real_function_3d >, std::vector< real_function_3d > > resultT
Definition CCStructures.h:1696
resultT allocator(World &world, const argtupleT &argtuple) const
Definition CCStructures.h:1698
std::tuple< const std::vector< int > &, const CC_vecfunction &, const std::vector< CCPair > &, const CC_vecfunction &, const std::vector< CCPair > &, const int &, const Info & > argtupleT
Definition CCStructures.h:1694
std::string basename
Definition CCStructures.h:1679
MacroTaskSinglesPotentialEx()
Definition CCStructures.h:1680
resultT operator()(const std::vector< int > &result_index, const CC_vecfunction &singles_gs, const std::vector< CCPair > &doubles_gs, const CC_vecfunction &singles_ex, const std::vector< CCPair > &doubles_ex, const int &name, const Info &info)
convenience function
Definition CCStructures.cc:674
Definition CCStructures.h:1715
std::string basename
Definition CCStructures.h:1717
std::tuple< const std::vector< int > &, const CC_vecfunction &, const std::vector< CCPair > &, const int &, const Info & > argtupleT
Definition CCStructures.h:1728
std::tuple< std::vector< real_function_3d >, std::vector< real_function_3d > > resultT
first vector is the potential, second is an intermediate (if applicable, e.g. for s2b and s2c potenti...
Definition CCStructures.h:1731
resultT operator()(const std::vector< int > &result_index, const CC_vecfunction &singles_gs, const std::vector< CCPair > &doubles_gs, const int &name, const Info &info)
Definition CCStructures.cc:716
MacroTaskSinglesPotentialGs()
Definition CCStructures.h:1718
resultT allocator(World &world, const argtupleT &argtuple) const
allocate the result and set the name of this task
Definition CCStructures.h:1734
class for holding the parameters for calculation
Definition QCCalculationParametersBase.h:290
virtual void read_input_and_commandline_options(World &world, const commandlineparser &parser, const std::string tag)
Definition QCCalculationParametersBase.h:325
Convolutions in separated form (including Gaussian)
Definition operator.h:139
static OperatorInfo combine_OT(const SeparatedConvolution< Q, NDIM > &left, const SeparatedConvolution< Q, NDIM > &right)
return operator type and other info of the combined operator (e.g. fg = f(1,2)* g(1,...
Definition operator.h:1706
A tensor is a multidimensional array.
Definition tensor.h:317
factory for generating TwoElectronInterfaces
Definition function_factory.h:443
A simple, fixed dimension vector.
Definition vector.h:64
void fence(bool debug=false)
Synchronizes all processes in communicator AND globally ensures no pending AM or tasks.
Definition worldgop.cc:161
std::vector< T > concat0(const std::vector< T > &v, size_t bufsz=1024 *1024)
Concatenate an STL vector of serializable stuff onto node 0.
Definition worldgop.h:953
void sum(T *buf, size_t nelem)
Inplace global sum while still processing AM & tasks.
Definition worldgop.h:870
A parallel world class.
Definition world.h:132
ProcessID rank() const
Returns the process rank in this World (same as MPI_Comm_rank()).
Definition world.h:320
WorldGopInterface & gop
Global operations.
Definition world.h:207
static std::enable_if_t< std::is_same< X, BinaryFstreamInputArchive >::value||std::is_same< X, BinaryFstreamOutputArchive >::value, bool > exists(World &world, const char *filename)
Returns true if the named, unopened archive exists on disk with read access.
Definition parallel_archive.h:224
Wraps an archive around a binary filestream for input.
Definition binary_fstream_archive.h:104
An archive for storing local or parallel data, wrapping a BinaryFstreamInputArchive.
Definition parallel_archive.h:366
An archive for storing local or parallel data wrapping a BinaryFstreamOutputArchive.
Definition parallel_archive.h:321
Objects that implement their own parallel archive interface should derive from this class.
Definition parallel_archive.h:58
Wraps an archive around an STL vector for input.
Definition vector_archive.h:101
Wraps an archive around an STL vector for output.
Definition vector_archive.h:55
double(* f1)(const coord_3d &)
Definition derivatives.cc:55
char * p(char *buf, const char *name, int k, int initial_level, double thresh, int order)
Definition derivatives.cc:72
static bool debug
Definition dirac-hatom.cc:16
auto T(World &world, response_space &f) -> response_space
Definition global_functions.cc:34
Tensor< typename Tensor< T >::scalar_type > arg(const Tensor< T > &t)
Return a new tensor holding the argument of each element of t (complex types only)
Definition tensor.h:2503
const int maxiter
Definition gygi_soltion.cc:68
static const double v
Definition hatom_sf_dirac.cc:20
static double u(double r, double c)
Definition he.cc:20
Tensor< double > op(const Tensor< double > &x)
Definition kain.cc:508
Declares the macrotaskq and MacroTaskBase classes.
#define MADNESS_CHECK(condition)
Check a condition — even in a release build the condition is always evaluated so it can have side eff...
Definition madness_exception.h:182
#define MADNESS_EXCEPTION(msg, value)
Macro for throwing a MADNESS exception.
Definition madness_exception.h:119
#define MADNESS_CHECK_THROW(condition, msg)
Check a condition — even in a release build the condition is always evaluated so it can have side eff...
Definition madness_exception.h:207
Main include file for MADNESS and defines Function interface.
Namespace for all elements and tools of MADNESS.
Definition DFParameters.h:10
long get_memory_usage()
Definition unique_filename.cc:29
static const char * filename
Definition legendre.cc:96
CalcType
Calculation Types used by CC2.
Definition CCStructures.h:27
@ CT_CC2
Definition CCStructures.h:28
@ CT_LRCC2
Definition CCStructures.h:28
@ CT_MP3
Definition CCStructures.h:28
@ CT_UNDEFINED
Definition CCStructures.h:28
@ CT_LRCCS
Definition CCStructures.h:28
@ CT_CISPD
Definition CCStructures.h:28
@ CT_TEST
Definition CCStructures.h:28
@ CT_MP2
Definition CCStructures.h:28
@ CT_ADC2
Definition CCStructures.h:28
@ CT_TDHF
Definition CCStructures.h:28
static std::string stringify(T arg)
Definition funcplot.h:1035
static double cpu_time()
Returns the cpu time in seconds relative to an arbitrary origin.
Definition timers.h:127
void print_memory_usage(const World &world)
check memory usage using getrusage
Definition CCStructures.h:77
Function< TENSOR_RESULT_TYPE(Q, T), NDIM > mul(const Q alpha, const Function< T, NDIM > &f, bool fence=true)
Returns new function equal to alpha*f(x) with optional fence.
Definition mra.h:1765
void truncate(World &world, response_space &v, double tol, bool fence)
Definition basic_operators.cc:30
CCState
Type of Pairs used by CC_Pair2 class.
Definition CCStructures.h:31
@ CCSTATE_UNDEFINED
Definition CCStructures.h:32
@ GROUND_STATE
Definition CCStructures.h:32
@ EXCITED_STATE
Definition CCStructures.h:32
FuncType
Definition ccpairfunction.h:26
@ RESPONSE
Definition ccpairfunction.h:26
@ HOLE
Definition ccpairfunction.h:26
@ UNDEFINED
Definition ccpairfunction.h:26
@ PARTICLE
Definition ccpairfunction.h:26
@ reconstructed
s coeffs at the leaves only
Definition funcdefaults.h:60
CalcType assign_calctype(const std::string name)
Assigns enum to string.
Definition CCStructures.cc:396
const std::vector< Function< T, NDIM > > & reconstruct(const std::vector< Function< T, NDIM > > &v)
reconstruct a vector of functions
Definition vmra.h:162
std::shared_ptr< CCConvolutionOperator< T, NDIM > > CCConvolutionOperatorPtr(World &world, const OpType type, typename CCConvolutionOperator< T, NDIM >::Parameters param)
Definition CCStructures.h:966
void hash_combine(hashT &seed, const T &v)
Combine hash values.
Definition worldhash.h:260
Pairs< Function< T, NDIM > > intermediateT
f12 and g12 intermediates of the form <f1|op|f2> (with op=f12 or op=g12) will be saved using the pair...
Definition CCStructures.h:502
double size_of(const intermediateT< T, NDIM > &im)
Returns the size of an intermediate.
Definition CCStructures.h:510
std::vector< real_function_3d > vector_real_function_3d
Definition functypedefs.h:94
std::shared_ptr< FunctionFunctorInterface< double, 3 > > func(new opT(g))
OpType
operator types
Definition operatorinfo.h:11
void print(const T &t, const Ts &... ts)
Print items to std::cout (items separated by spaces) and terminate with a new line.
Definition print.h:225
response_space apply(World &world, std::vector< std::vector< std::shared_ptr< real_convolution_3d > > > &op, response_space &f)
Definition basic_operators.cc:39
std::string get_hostname()
Definition unique_filename.cc:40
NDIM & f
Definition mra.h:2481
std::size_t hashT
The hash value type.
Definition worldhash.h:145
double wall_time()
Returns the wall time in seconds relative to an arbitrary origin.
Definition timers.cc:48
std::string type(const PairType &n)
Definition PNOParameters.h:18
constexpr Vector< T, sizeof...(Ts)+1 > vec(T t, Ts... ts)
Factory function for creating a madness::Vector.
Definition vector.h:750
PotentialType
CC2 Singles Potentials.
Definition CCStructures.h:36
@ POT_singles_
Definition CCStructures.h:53
@ POT_s2b_
Definition CCStructures.h:45
@ POT_F3D_
Definition CCStructures.h:38
@ POT_s5b_
Definition CCStructures.h:43
@ POT_s4c_
Definition CCStructures.h:49
@ POT_s5c_
Definition CCStructures.h:44
@ POT_s6_
Definition CCStructures.h:50
@ POT_s4b_
Definition CCStructures.h:48
@ POT_ccs_
Definition CCStructures.h:51
@ POT_s3c_
Definition CCStructures.h:41
@ POT_s4a_
Definition CCStructures.h:47
@ POT_s5a_
Definition CCStructures.h:42
@ POT_s3b_
Definition CCStructures.h:40
@ POT_s2c_
Definition CCStructures.h:46
@ POT_cis_
Definition CCStructures.h:52
@ POT_UNDEFINED
Definition CCStructures.h:37
@ POT_s3a_
Definition CCStructures.h:39
std::string assign_name(const CCState &input)
Assigns strings to enums for formated output.
Definition CCStructures.cc:379
std::string name(const FuncType &type, const int ex=-1)
Definition ccpairfunction.h:28
madness::hashT hash_value(const std::array< T, N > &a)
Hash std::array with madness hash.
Definition array_addons.h:78
void save(const Function< T, NDIM > &f, const std::string name)
Definition mra.h:2835
double get_size(World &world, const std::vector< Function< T, NDIM > > &v)
Definition vmra.h:1851
double get_size_local(World &world, const std::vector< Function< T, NDIM > > &v)
return the size of a vector of functions for each rank
Definition vmra.h:1832
Definition mraimpl.h:50
static const double b
Definition nonlinschro.cc:119
static const double a
Definition nonlinschro.cc:118
static const double c
Definition relops.cc:10
static const double thresh
Definition rk.cc:45
double thresh
Definition tdse.cc:67
parameter class
Definition CCStructures.h:763
int freeze
Definition CCStructures.h:778
Parameters()
Definition CCStructures.h:764
void serialize(archiveT &ar)
f12 exponent
Definition CCStructures.h:782
double lo
Definition CCStructures.h:777
double gamma
Definition CCStructures.h:779
Parameters(const CCParameters &param)
Definition CCStructures.h:773
double thresh_op
Definition CCStructures.h:776
Parameters(const Parameters &other)
Definition CCStructures.h:766
little helper structure which manages the stored singles potentials
Definition CCStructures.h:972
CCParameters parameters
Definition CCStructures.h:1078
vector_real_function_3d current_s2c_potential_ex_
s2c_potential for the pure 6D-part of the excited_state (expensive and constant during singles iterat...
Definition CCStructures.h:1092
bool potential_exists(const CC_vecfunction &f, const PotentialType &type) const
check if the intermediate potential exists
Definition CCStructures.h:979
Recordlist< Cloud::keyT > cloud_store(World &world, Cloud &cloud) const
Definition CCStructures.h:1035
void reconstruct() const
Definition CCStructures.h:1004
vector_real_function_3d operator()(const CC_vecfunction &f, const PotentialType &type, const bool throw_if_empty) const
fetches the correct stored potential or throws an exception
Definition CCStructures.cc:125
vector_real_function_3d current_singles_potential_gs_
whole ground state singles potential without fock-residue
Definition CCStructures.h:1082
CCIntermediatePotentials & operator=(const CCIntermediatePotentials &other)=default
void clear_response()
clears only potentials of the response
Definition CCStructures.h:1025
vector_real_function_3d current_s2c_potential_gs_
s2c_potential for the pure 6D-part of the ground-state (expensive and constant during singles iterati...
Definition CCStructures.h:1090
vector_real_function_3d current_singles_potential_ex_
whole excited state singles potential without fock-residue
Definition CCStructures.h:1084
bool potential_exists(const PotentialType &type, const FuncType &ftype) const
check if the intermediate potential exists
Definition CCStructures.h:984
void cloud_load(World &world, const Cloud &cloud, Recordlist< Cloud::keyT > &recordlist)
Definition CCStructures.h:1048
CCIntermediatePotentials(const CCIntermediatePotentials &other)=default
CCIntermediatePotentials(const CCParameters &p)
Definition CCStructures.h:974
vector_real_function_3d unprojected_cc2_projector_response_
Definition CCStructures.h:1095
friend hashT hash_value(const CCIntermediatePotentials &ip)
Definition CCStructures.h:1059
vector_real_function_3d current_s2b_potential_gs_
s2b_potential for the pure 6D-part of the ground-state (expensive and constant during singles iterati...
Definition CCStructures.h:1086
vector_real_function_3d current_s2b_potential_ex_
s2b_potential for the pure 6D-part of the excited-state (expensive and constant during singles iterat...
Definition CCStructures.h:1088
void insert(const vector_real_function_3d &potential, const CC_vecfunction &f, const PotentialType &type)
insert potential
Definition CCStructures.cc:140
void clear_all()
deltes all stored potentials
Definition CCStructures.h:1015
vector_real_function_3d get_potential(const PotentialType &ptype, const FuncType &ftype, const bool throw_if_empty) const
return a vector of the intermediate potentials
Definition CCStructures.cc:97
void output(const std::string &msg) const
structured output
Definition CCStructures.h:1098
Definition CCStructures.h:90
void print_warnings() const
Definition CCStructures.h:116
void warning(const std::string &msg) const
Definition CCStructures.cc:45
void debug_output(const std::string &msg) const
Definition CCStructures.h:100
bool debug
Definition CCStructures.h:96
void subsection(const std::string &msg) const
Definition CCStructures.cc:34
CCMessenger operator<<(const T &t) const
Definition CCStructures.h:121
World & world
Definition CCStructures.h:93
bool scientific
Definition CCStructures.h:95
std::vector< std::string > warnings
collect all warnings that occur to print out at the end of the job
Definition CCStructures.h:128
std::ostream & os
output stream
Definition CCStructures.h:130
void section(const std::string &msg) const
Definition CCStructures.cc:23
void output(const std::string &msg) const
Definition CCStructures.cc:14
CCMessenger(World &world)
Definition CCStructures.h:91
size_t output_prec
Definition CCStructures.h:94
void operator()(const std::string &msg) const
Definition CCStructures.h:98
Definition CCStructures.h:212
double thresh_Ue() const
Definition CCStructures.h:316
double thresh_f12() const
Definition CCStructures.h:314
std::size_t kain_subspace() const
Definition CCStructures.h:366
double tight_thresh_6D() const
Definition CCStructures.h:306
std::size_t iter_max_3D() const
Definition CCStructures.h:328
bool no_compute_cispd() const
Definition CCStructures.h:348
CCParameters(World &world, const commandlineparser &parser)
ctor reading out the input file
Definition CCStructures.h:222
bool no_compute_mp2_constantpart() const
Definition CCStructures.h:340
std::pair< int, int > only_pair() const
Definition CCStructures.h:332
bool kain() const
Definition CCStructures.h:356
bool plot() const
Definition CCStructures.h:354
bool no_compute_response() const
Definition CCStructures.h:342
double thresh_poisson() const
Definition CCStructures.h:312
CCParameters()
Definition CCStructures.h:214
double thresh_bsh_3D() const
Definition CCStructures.h:308
bool no_compute_mp2() const
Definition CCStructures.h:344
double dconv_6D() const
Definition CCStructures.h:324
double econv_pairs() const
Definition CCStructures.h:320
void initialize_parameters()
Definition CCStructures.h:229
bool response() const
Definition CCStructures.h:295
bool decompose_Q() const
Definition CCStructures.h:360
double thresh_bsh_6D() const
Definition CCStructures.h:310
void error(World &world, const std::string &msg) const
Definition CCStructures.h:380
CCParameters(const CCParameters &other)=default
copy constructor
double gamma() const
Definition CCStructures.h:372
double thresh_3D() const
Definition CCStructures.h:300
double tight_thresh_3D() const
Definition CCStructures.h:302
bool no_compute() const
Definition CCStructures.h:336
double dconv_3D() const
Definition CCStructures.h:322
std::size_t iter_max() const
Definition CCStructures.h:326
double lo() const
Definition CCStructures.h:296
long freeze() const
Definition CCStructures.h:368
double thresh_6D() const
Definition CCStructures.h:304
bool no_compute_cc2() const
Definition CCStructures.h:346
std::vector< std::size_t > excitations() const
Definition CCStructures.h:370
void set_derived_values()
Definition CCStructures.cc:159
bool QtAnsatz() const
Definition CCStructures.h:362
bool test() const
Definition CCStructures.h:358
double dmin() const
Definition CCStructures.h:298
std::size_t output_prec() const
Definition CCStructures.h:364
bool restart() const
Definition CCStructures.h:334
double econv() const
Definition CCStructures.h:318
std::size_t iter_max_6D() const
Definition CCStructures.h:330
CalcType calc_type() const
Definition CCStructures.h:282
bool no_compute_gs() const
Definition CCStructures.h:338
bool debug() const
Definition CCStructures.h:352
void information(World &world) const
print out the parameters
Definition CCStructures.cc:191
bool no_compute_lrcc2() const
Definition CCStructures.h:350
size_t warning(World &world, const std::string &msg) const
Definition CCStructures.h:387
void sanity_check(World &world) const
check if parameters are set correct
Definition CCStructures.cc:202
print accumulated size of all functions
Definition CCStructures.h:1444
void print(World &world, const std::string msg="") const
Definition CCStructures.h:1468
CCSize()=default
double size_local
Definition CCStructures.h:1445
void add_helper(const std::vector< CCPair > &vp)
Definition CCStructures.h:1454
void add(const Args &... args)
variadic template parameters to add the size of all functions and pairs
Definition CCStructures.h:1464
void add_helper(const std::vector< Function< T, NDIM > > &v)
Definition CCStructures.h:1450
Timer Structure.
Definition CCStructures.h:135
std::pair< double, double > current_time(bool printout=false)
Definition CCStructures.h:188
CCTimer(World &world, std::string msg)
Definition CCStructures.h:139
void print() const
Definition CCStructures.h:197
std::string operation
Definition CCStructures.h:146
double start_cpu
Definition CCStructures.h:145
double time_wall
Definition CCStructures.h:149
double get_wall_time_diff() const
Definition CCStructures.h:184
void update_time()
Definition CCStructures.h:152
CCTimer stop()
Definition CCStructures.h:168
CCTimer start()
Definition CCStructures.h:162
void print()
Definition CCStructures.h:193
double time_cpu
Definition CCStructures.h:150
double start_wall
Definition CCStructures.h:144
double get_cpu_time_diff() const
Definition CCStructures.h:186
void print(const std::pair< double, double > &times) const
Definition CCStructures.h:201
double reset()
Definition CCStructures.h:176
World & world
Definition CCStructures.h:143
double end_wall
Definition CCStructures.h:147
double end_cpu
Definition CCStructures.h:148
A helper structure which holds a map of functions.
Definition CCStructures.h:522
std::string irrep
Definition CCStructures.h:665
hashT hash() const
Definition CCStructures.h:651
CC_vecfunction(const vector_real_function_3d &v, const FuncType &type, const size_t &freeze)
Definition CCStructures.h:549
std::map< std::size_t, CCFunction< double, 3 > > CC_functionmap
Definition CCStructures.h:658
CC_vecfunction(const CC_vecfunction &other)
copy ctor (shallow)
Definition CCStructures.h:565
const CCFunction< double, 3 > & operator()(const CCFunction< double, 3 > &i) const
getter
Definition CCStructures.h:677
void insert(const size_t &i, const CCFunction< double, 3 > &f)
setter
Definition CCStructures.h:697
CC_vecfunction(const vector_real_function_3d &v, const FuncType &type)
Definition CCStructures.h:541
static CC_vecfunction load_restartdata(World &world, std::string filename)
Definition CCStructures.h:613
const CCFunction< double, 3 > & operator()(const size_t &i) const
getter
Definition CCStructures.h:682
CC_vecfunction operator*(const double &fac) const
scalar multiplication
Definition CCStructures.h:727
double delta
Definition CCStructures.h:664
CCFunction< double, 3 > & operator()(const size_t &i)
getter
Definition CCStructures.h:692
void print_size(const std::string &msg="!?not assigned!?") const
Print the memory of which is used by all the functions in the map.
Definition CCStructures.cc:69
CC_vecfunction(const std::vector< CCFunction< double, 3 > > &v)
Definition CCStructures.h:535
bool operator<(const CC_vecfunction &b) const
operator needed for sort operation (sorted by omega values)
Definition CCStructures.h:741
CC_vecfunction(const FuncType type_)
Definition CCStructures.h:526
void serialize(const Archive &ar)
Definition CCStructures.h:626
CC_vecfunction(const std::vector< CCFunction< double, 3 > > &v, const FuncType type_)
Definition CCStructures.h:559
CC_vecfunction(const vector_real_function_3d &v)
Definition CCStructures.h:528
CC_vecfunction()
Definition CCStructures.h:524
void set_functions(const vector_real_function_3d &v, const FuncType &type, const size_t &freeze)
setter
Definition CCStructures.h:702
CCFunction< double, 3 > & operator()(const CCFunction< double, 3 > &i)
getter
Definition CCStructures.h:687
void scale(const double &factor)
scaling (inplace)
Definition CCStructures.h:734
void plot(const std::string &msg="") const
Definition CCStructures.h:744
FuncType type
Definition CCStructures.h:661
double current_error
excitation energy
Definition CCStructures.h:663
friend CC_vecfunction copy(const CC_vecfunction &other)
returns a deep copy (void shallow copy errors)
Definition CCStructures.h:587
size_t size() const
Get the size vector (number of functions in the map)
Definition CCStructures.h:718
CC_vecfunction & operator=(const CC_vecfunction &other)
assignment operator, shallow wrt the functions
Definition CCStructures.h:573
double omega
Definition CCStructures.h:662
bool is_converged(const double econv, const double dconv) const
Definition CCStructures.h:672
vector_real_function_3d get_vecfunction() const
Returns all the functions of the map as vector.
Definition CCStructures.h:711
void save_restartdata(World &world, std::string filename) const
Definition CCStructures.h:620
CC_functionmap functions
Definition CCStructures.h:659
std::string name(const int ex) const
excitation irrep (direct product of x function and corresponding orbital)
Definition CCStructures.h:668
void reconstruct() const
Definition CCStructures.h:596
POD holding some basic functions and some intermediates for the CC2 calculation.
Definition CCStructures.h:1107
void reconstruct() const
Definition CCStructures.h:1130
std::vector< Function< double, 3 > > mo_ket
Definition CCStructures.h:1108
Recordlist< Cloud::keyT > cloud_store(World &world, Cloud &cloud) const
customized function to store this to the cloud
Definition CCStructures.h:1143
Tensor< double > fock
Definition CCStructures.h:1113
Function< double, 3 > R
Definition CCStructures.h:1115
std::vector< Function< double, 3 > > U1
Definition CCStructures.h:1116
CCIntermediatePotentials intermediate_potentials
Definition CCStructures.h:1114
Function< double, 3 > U2
Definition CCStructures.h:1115
std::vector< madness::Vector< double, 3 > > molecular_coordinates
Definition CCStructures.h:1110
std::vector< double > orbital_energies
Definition CCStructures.h:1112
std::vector< Function< double, 3 > > mo_bra
Definition CCStructures.h:1109
CCParameters parameters
Definition CCStructures.h:1111
vector_real_function_3d get_active_mo_bra() const
Definition CCStructures.h:1124
void cloud_load(World &world, const Cloud &cloud, Recordlist< Cloud::keyT > &recordlist)
customized function to load this from the cloud
Definition CCStructures.h:1162
Function< double, 3 > R_square
Definition CCStructures.h:1115
vector_real_function_3d get_active_mo_ket() const
Definition CCStructures.h:1118
Definition CCStructures.h:394
static PairVectorMap triangular_map(const int nfreeze, const int nocc)
Definition CCStructures.h:400
void print(const std::string msg="PairVectorMap") const
Definition CCStructures.h:420
std::vector< std::pair< int, int > > map
maps pair index (i,j) to vector index k
Definition CCStructures.h:396
static PairVectorMap quadratic_map(const int nfreeze, const int nocc)
Definition CCStructures.h:410
PairVectorMap(const std::vector< std::pair< int, int > > map1)
Definition CCStructures.h:398
Definition CCStructures.h:434
void swap(Pairs< T > &other)
swap the contant of the pairmap
Definition CCStructures.h:490
pairmapT allpairs
Definition CCStructures.h:437
static Pairs vector2pairs(const std::vector< T > &argument, const PairVectorMap map)
Definition CCStructures.h:453
Pairs< R > convert(const Pairs< T > arg, const opT op) const
convert Pairs<T> to another type
Definition CCStructures.h:443
std::map< std::pair< int, int >, T > pairmapT
Definition CCStructures.h:436
bool empty() const
Definition CCStructures.h:494
T & operator()(int i, int j)
getter
Definition CCStructures.h:477
void insert(int i, int j, const T &pair)
Definition CCStructures.h:484
const T & operator()(int i, int j) const
getter
Definition CCStructures.h:470
static std::vector< T > pairs2vector(const Pairs< T > &argument, const PairVectorMap map)
Definition CCStructures.h:461
Definition cloud.h:34
very simple command line parser
Definition commandlineparser.h:15
Definition lowrankfunction.h:332
static double current_time
Definition tdse1d.cc:160
InputParameters param
Definition tdse.cc:203
double norm(const T i1)
Definition test_cloud.cc:72
constexpr std::size_t NDIM
Definition testgconv.cc:54
double h(const coord_1d &r)
Definition testgconv.cc:175