-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathobs_dkerg.cpp
111 lines (90 loc) · 2.92 KB
/
obs_dkerg.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
/*
* Copyright (c) 2013, Robert Rueger <[email protected]>
*
* This file is part of hVMC.
*
* hVMC is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* hVMC is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with hVMC. If not, see <http://www.gnu.org/licenses/>.
*/
#include "obs_dkerg.hpp"
#if VERBOSE >= 1
# include <iostream>
#endif
#include <boost/mpi/collectives.hpp>
#include "macros.h"
#include "serialization_eigen.hpp"
using namespace std;
namespace mpi = boost::mpi;
ObservableDeltaKEnergy::ObservableDeltaKEnergy(
unsigned int num_vpar, unsigned int optimizers_init )
: optimizers( optimizers_init ),
thisbin_DkE_sum( Eigen::VectorXd::Zero( num_vpar ) ),
thisbin_count( 0 ),
binmean_DkE_sum( Eigen::VectorXd::Zero( num_vpar ) ),
binmean_count( 0 ) { }
void ObservableDeltaKEnergy::measure(
const ModelManager& model, ObservableCache& cache )
{
if ( !cache.DeltaK ) {
cache.DeltaK = model.Delta_k( optimizers );
}
if ( !cache.E ) {
cache.E = model.E_l();
}
const Eigen::VectorXd& DkE_current = cache.DeltaK.get() * cache.E.get();
thisbin_DkE_sum += DkE_current;
++thisbin_count;
#if VERBOSE >= 1
cout << "ObservableDeltaKEnergy::measure() : thisbin_DkE_sum = " << endl
<< thisbin_DkE_sum.transpose() << endl;
#endif
}
void ObservableDeltaKEnergy::completebin()
{
binmean_DkE_sum += thisbin_DkE_sum / static_cast<double>( thisbin_count );
++binmean_count;
thisbin_DkE_sum.setZero();
thisbin_count = 0;
}
void ObservableDeltaKEnergy::collect_and_write_results(
const mpi::communicator& mpicomm,
MCCResults& results ) const
{
assert( mpicomm.rank() == 0 );
vector<Eigen::VectorXd> binmeans_collector(
mpicomm.size(),
Eigen::MatrixXd( binmean_DkE_sum.rows(), binmean_DkE_sum.cols() )
);
mpi::gather( mpicomm, binmean_DkE_sum, binmeans_collector, 0 );
vector<unsigned int> binmeans_collector_count;
mpi::gather( mpicomm, binmean_count, binmeans_collector_count, 0 );
results.Deltak_E
= accumulate(
binmeans_collector.begin() + 1,
binmeans_collector.end(),
binmeans_collector.front()
) / static_cast<double>(
accumulate(
binmeans_collector_count.begin(),
binmeans_collector_count.end(),
0
)
);
}
void ObservableDeltaKEnergy::send_results_to_master(
const mpi::communicator& mpicomm ) const
{
assert( mpicomm.rank() != 0 );
mpi::gather( mpicomm, binmean_DkE_sum, 0 );
mpi::gather( mpicomm, binmean_count, 0 );
}