diff options
author | Jaron Kent-Dobias <jaron@kent-dobias.com> | 2018-07-09 14:29:16 -0400 |
---|---|---|
committer | Jaron Kent-Dobias <jaron@kent-dobias.com> | 2018-07-09 14:29:16 -0400 |
commit | 88086fc222e1802d2a68edf5f1097cf9685ec42c (patch) | |
tree | 46a6830da96fa213ac93c6a952af9f9cb9f403b3 /lib/orthogonal.h | |
parent | 466812e61e2ccec7750c791835111b402938411c (diff) | |
download | c++-88086fc222e1802d2a68edf5f1097cf9685ec42c.tar.gz c++-88086fc222e1802d2a68edf5f1097cf9685ec42c.tar.bz2 c++-88086fc222e1802d2a68edf5f1097cf9685ec42c.zip |
removed some references to the specific form of the magnetization for vector models from wolff.h
Diffstat (limited to 'lib/orthogonal.h')
-rw-r--r-- | lib/orthogonal.h | 12 |
1 files changed, 12 insertions, 0 deletions
diff --git a/lib/orthogonal.h b/lib/orthogonal.h index 0a2b5c7..2d0e1a1 100644 --- a/lib/orthogonal.h +++ b/lib/orthogonal.h @@ -161,4 +161,16 @@ void generate_rotation (gsl_rng *r, orthogonal_t <q, double> *ptr) { } } +template <q_t q, class T> +void write_magnetization(vector_t <q, T> M, FILE *outfile) { + fwrite(M.x, sizeof(double), q, outfile); +} + +template <q_t q> // save some space and don't write whole doubles +void write_magnetization(vector_t <q, double> M, FILE *outfile) { + for (q_t i = 0; i < q; i++) { + float M_tmp = (float)M.x[i]; + fwrite(&M_tmp, sizeof(float), 1, outfile); + } +} |