summaryrefslogtreecommitdiff
path: root/lib/include/wolff/measurement.hpp
blob: a6a5f7973dfc52716c848532c6024970719c367e (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24

#ifndef WOLFF_MEASUREMENTS
#define WOLFF_MEASUREMENTS

#include "system.hpp"

template <class R_t, class X_t>
class wolff_measurement {
  public:
    virtual void pre_cluster(N_t, N_t, const wolff_system<R_t, X_t>&, v_t, const R_t&) = 0;

    virtual void plain_bond_visited(const wolff_system<R_t, X_t>&, v_t, const X_t&, v_t, double) = 0;
    virtual void plain_site_transformed(const wolff_system<R_t, X_t>&, v_t, const X_t&) = 0;

#ifndef WOLFF_NO_FIELD
    virtual void ghost_bond_visited(const wolff_system<R_t, X_t>&, v_t, const X_t&, const X_t&, double) = 0;
    virtual void ghost_site_transformed(const wolff_system<R_t, X_t>&, const R_t&) = 0;
#endif

    virtual void post_cluster(N_t, N_t, const wolff_system<R_t, X_t>&) = 0;
};

#endif