|
1 | 1 | #ifndef __CLIB__ |
2 | 2 | #define __CLIB__ |
3 | 3 |
|
4 | | -#include<math.h> |
5 | | -#include<complex.h> |
6 | | -#include<fftw3.h> |
| 4 | +#include <complex.h> |
| 5 | +#include <fftw3.h> |
| 6 | +#include <math.h> |
7 | 7 | //#include<omp.h> |
8 | 8 |
|
9 | | -#include"fidimag_random.h" |
| 9 | +#include "fidimag_random.h" |
10 | 10 |
|
11 | 11 | #define WIDE_PI 3.1415926535897932384626433832795L |
12 | 12 |
|
13 | 13 | /* 3 components for the cross product calculations */ |
14 | | -inline double cross_x(double a0, double a1, double a2, |
15 | | - double b0, double b1, double b2) { return a1 * b2 - a2 * b1; } |
16 | | -inline double cross_y(double a0, double a1, double a2, |
17 | | - double b0, double b1, double b2) { return a2 * b0 - a0 * b2; } |
18 | | -inline double cross_z(double a0, double a1, double a2, |
19 | | - double b0, double b1, double b2) { return a0 * b1 - a1 * b0; } |
20 | | - |
21 | | -void compute_exch_field(double *spin, double *field, double *energy, |
22 | | - double Jx, double Jy, double Jz, |
23 | | - int *ngbs, int n); |
24 | | - |
25 | | - |
26 | | -void compute_exch_field_spatial(double *spin, double *field, double *energy,double *J, |
27 | | - int *ngbs, int n); |
| 14 | +inline double cross_x(double a0, double a1, double a2, double b0, double b1, |
| 15 | + double b2) { |
| 16 | + return a1 * b2 - a2 * b1; |
| 17 | +} |
| 18 | +inline double cross_y(double a0, double a1, double a2, double b0, double b1, |
| 19 | + double b2) { |
| 20 | + return a2 * b0 - a0 * b2; |
| 21 | +} |
| 22 | +inline double cross_z(double a0, double a1, double a2, double b0, double b1, |
| 23 | + double b2) { |
| 24 | + return a0 * b1 - a1 * b0; |
| 25 | +} |
| 26 | + |
| 27 | +void compute_exch_field(double *spin, double *field, double *energy, double Jx, |
| 28 | + double Jy, double Jz, int *ngbs, int n); |
| 29 | + |
| 30 | +void compute_exch_field_spatial(double *spin, double *field, double *energy, |
| 31 | + double *J, int *ngbs, int n); |
28 | 32 |
|
29 | 33 | double compute_exch_energy(double *spin, double Jx, double Jy, double Jz, |
30 | | - int nx, int ny, int nz, |
31 | | - int xperiodic, int yperiodic); |
| 34 | + int nx, int ny, int nz, int xperiodic, |
| 35 | + int yperiodic); |
32 | 36 |
|
33 | | -void compute_anis(double *spin, double *field, double *energy, |
34 | | - double *Ku, double *axis, int n); |
| 37 | +void compute_anis(double *spin, double *field, double *energy, double *Ku, |
| 38 | + double *axis, int n); |
35 | 39 |
|
36 | | -void dmi_field_bulk(double *spin, double *field, double *energy, |
37 | | - double *D, int *ngbs, int n); |
| 40 | +void dmi_field_bulk(double *spin, double *field, double *energy, double *D, |
| 41 | + int *ngbs, int n); |
38 | 42 |
|
39 | 43 | void dmi_field_interfacial_atomistic(double *spin, double *field, |
40 | | - double *energy, double D, int *ngbs, |
41 | | - int n, int nneighbours, |
42 | | - double *DMI_vec); |
| 44 | + double *energy, double D, int *ngbs, int n, |
| 45 | + int nneighbours, double *DMI_vec); |
43 | 46 |
|
44 | | -void demag_full(double *spin, double *field, double *energy, |
45 | | - double *coords, |
| 47 | +void demag_full(double *spin, double *field, double *energy, double *coords, |
46 | 48 | double *mu_s, double *mu_s_scale, int n); |
47 | 49 |
|
48 | | -double dmi_energy(double *spin, double D, int nx, int ny, int nz, |
49 | | - int xperiodic, int yperiodic); |
| 50 | +double dmi_energy(double *spin, double D, int nx, int ny, int nz, int xperiodic, |
| 51 | + int yperiodic); |
50 | 52 |
|
51 | | -void llg_rhs(double * dm_dt, double * spin, double * h, double *alpha, |
52 | | - int *pins, double gamma, int n, int do_precession, |
53 | | - double default_c); |
| 53 | +void llg_rhs(double *dm_dt, double *spin, double *h, double *alpha, int *pins, |
| 54 | + double gamma, int n, int do_precession, double default_c); |
54 | 55 |
|
55 | | -void llg_rhs_jtimes(double *jtn, double *m, double *h, |
56 | | - double *mp, double *hp, double *alpha, int *pins, |
57 | | - double gamma, int n, int do_precession, double default_c); |
| 56 | +void llg_rhs_jtimes(double *jtn, double *m, double *h, double *mp, double *hp, |
| 57 | + double *alpha, int *pins, double gamma, int n, |
| 58 | + int do_precession, double default_c); |
58 | 59 |
|
59 | | -void llg_s_rhs(double * dm_dt, double * spin, double * h, double *alpha, |
60 | | - double *chi, double gamma, int n); |
| 60 | +void llg_s_rhs(double *dm_dt, double *spin, double *h, double *alpha, |
| 61 | + double *chi, double gamma, int n); |
61 | 62 |
|
| 63 | +void compute_stt_field_c(double *spin, double *field, double *jx, double *jy, |
| 64 | + double *jz, double dx, double dy, double dz, int *ngbs, |
| 65 | + int n); |
62 | 66 |
|
63 | | -void compute_stt_field_c(double *spin, double *field, double *jx, double *jy, double *jz, |
64 | | - double dx, double dy, double dz, int *ngbs, int n); |
65 | | - |
66 | | -void llg_stt_rhs(double *dm_dt, double *m, double *h, |
67 | | - double *h_stt, double *alpha, |
68 | | - double beta, double u0, double gamma, int n); |
69 | | - |
70 | | -void llg_stt_cpp(double *dm_dt, double *m, double *h, double *p, |
71 | | - double *alpha, int *pins, double *a_J, double beta, double gamma, int n); |
| 67 | +void llg_stt_rhs(double *dm_dt, double *m, double *h, double *h_stt, |
| 68 | + double *alpha, double beta, double u0, double gamma, int n); |
72 | 69 |
|
| 70 | +void llg_stt_cpp(double *dm_dt, double *m, double *h, double *p, double *alpha, |
| 71 | + int *pins, double *a_J, double beta, double gamma, int n); |
73 | 72 |
|
74 | 73 | void normalise(double *m, int *pins, int n); |
75 | 74 |
|
76 | | -double skyrmion_number(double *spin, double *charge, |
77 | | - int nx, int ny, int nz, int *ngbs); |
| 75 | +double skyrmion_number(double *spin, double *charge, int nx, int ny, int nz, |
| 76 | + int *ngbs); |
78 | 77 |
|
79 | | -double skyrmion_number_BergLuscher(double *spin, double *charge, |
80 | | - int nx, int ny, int nz, int *ngbs); |
| 78 | +double skyrmion_number_BergLuscher(double *spin, double *charge, int nx, int ny, |
| 79 | + int nz, int *ngbs); |
81 | 80 |
|
82 | | -void compute_guiding_center(double *spin, int nx, int ny, int nz, double *res); |
| 81 | +void compute_guiding_center(double *spin, int nx, int ny, int nz, int nx_start, |
| 82 | + int nx_stop, int ny_start, int ny_stop, |
| 83 | + double *res); |
83 | 84 |
|
84 | | -void compute_px_py_c(double *spin, int nx, int ny, int nz, |
85 | | - double *px, double *py); |
| 85 | +void compute_px_py_c(double *spin, int nx, int ny, int nz, double *px, |
| 86 | + double *py); |
86 | 87 |
|
87 | 88 | //====================================================================== |
88 | 89 |
|
89 | | -void llg_rhs_dw_c(double *m, double *h, double *dm, double *T, double *alpha, |
90 | | - double *mu_s_inv, int *pins, double *eta, int n, double gamma, double dt); |
| 90 | +void llg_rhs_dw_c(double *m, double *h, double *dm, double *T, double *alpha, |
| 91 | + double *mu_s_inv, int *pins, double *eta, int n, double gamma, |
| 92 | + double dt); |
91 | 93 |
|
92 | 94 | //====================================================================== |
93 | 95 |
|
94 | | -void run_step_mc(mt19937_state *state, double *spin, double *new_spin, int *ngbs, int *nngbs, double J, double J1, double D, double D1, double *h, double Kc, int n, double T, int hexagnoal_mesh); |
95 | | - |
| 96 | +void run_step_mc(mt19937_state *state, double *spin, double *new_spin, |
| 97 | + int *ngbs, int *nngbs, double J, double J1, double D, |
| 98 | + double D1, double *h, double Kc, int n, double T, |
| 99 | + int hexagnoal_mesh); |
96 | 100 |
|
97 | 101 | #endif |
0 commit comments