-
Notifications
You must be signed in to change notification settings - Fork 31
/
Copy pathsystem.h
35 lines (26 loc) · 1010 Bytes
/
system.h
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
#pragma once
#include <memory>
#include <vector>
class System {
public:
System(
std::unique_ptr<class Hamiltonian> hamiltonian,
std::unique_ptr<class WaveFunction> waveFunction,
std::unique_ptr<class MonteCarlo> solver,
std::vector<std::unique_ptr<class Particle>> particles);
unsigned int runEquilibrationSteps(
double stepLength,
unsigned int numberOfEquilibrationSteps);
std::unique_ptr<class Sampler> runMetropolisSteps(
double stepLength,
unsigned int numberOfMetropolisSteps);
double computeLocalEnergy();
const std::vector<double>& getWaveFunctionParameters();
private:
unsigned int m_numberOfParticles = 0;
unsigned int m_numberOfDimensions = 0;
std::unique_ptr<class Hamiltonian> m_hamiltonian;
std::unique_ptr<class WaveFunction> m_waveFunction;
std::unique_ptr<class MonteCarlo> m_solver;
std::vector<std::unique_ptr<class Particle>> m_particles;
};