summaryrefslogtreecommitdiff
path: root/lib/orthogonal.h
diff options
context:
space:
mode:
Diffstat (limited to 'lib/orthogonal.h')
-rw-r--r--lib/orthogonal.h12
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);
+ }
+}