summaryrefslogtreecommitdiff
path: root/lib/cluster.h
diff options
context:
space:
mode:
authorJaron Kent-Dobias <jaron@kent-dobias.com>2018-07-20 22:57:39 -0400
committerJaron Kent-Dobias <jaron@kent-dobias.com>2018-07-20 22:57:39 -0400
commit5ffaf0a1bb0f0b47d57d0f24ee1134659775dacb (patch)
tree230c9562222b7858316ac1bb59bb3e8570746df4 /lib/cluster.h
parent72301b3d5c3a91ff2e7fc6eedcad7bce8e647efa (diff)
downloadc++-5ffaf0a1bb0f0b47d57d0f24ee1134659775dacb.tar.gz
c++-5ffaf0a1bb0f0b47d57d0f24ee1134659775dacb.tar.bz2
c++-5ffaf0a1bb0f0b47d57d0f24ee1134659775dacb.zip
added ising example to cpp collection
Diffstat (limited to 'lib/cluster.h')
-rw-r--r--lib/cluster.h14
1 files changed, 8 insertions, 6 deletions
diff --git a/lib/cluster.h b/lib/cluster.h
index 2225e2f..4b3c2f6 100644
--- a/lib/cluster.h
+++ b/lib/cluster.h
@@ -23,6 +23,8 @@
#include "measurement.h"
#include "vector.h"
#include "orthogonal.h"
+#include "ising.h"
+#include "z2.h"
#include "dihedral.h"
#include "dihinf.h"
#include "yule_walker.h"
@@ -107,17 +109,17 @@ void flip_cluster(state_t <R_t, X_t> *state, v_t v0, R_t r, gsl_rng *rand) {
double dE = state->H(rs_old) - state->H(rs_new);
prob = 1.0 - exp(-dE / state->T);
- subtract (&(state->M), rs_old);
- add (&(state->M), rs_new);
+ add(&(state->M), -1, rs_old);
+ add(&(state->M), 1, rs_new);
state->E += dE;
for (D_t i = 0; i < state->D; i++) {
double x = (double)((non_ghost / (v_t)pow(state->L, state->D - i - 1)) % state->L) / (double)state->L;
- scalar_subtract(&(state->ReF[i]), cos(2 * M_PI * x), rs_old);
- scalar_add(&(state->ReF[i]), cos(2 * M_PI * x), rs_new);
+ add(&(state->ReF[i]), -cos(2 * M_PI * x), rs_old);
+ add(&(state->ReF[i]), cos(2 * M_PI * x), rs_new);
- scalar_subtract(&(state->ImF[i]), sin(2 * M_PI * x), rs_old);
- scalar_add(&(state->ImF[i]), sin(2 * M_PI * x), rs_new);
+ add(&(state->ImF[i]), -sin(2 * M_PI * x), rs_old);
+ add(&(state->ImF[i]), sin(2 * M_PI * x), rs_new);
}
free_spin (rs_old);