|
1 | 1 | import fidimag.extensions.dipolar as clib |
2 | 2 | import numpy as np |
3 | 3 | from .energy import Energy |
| 4 | +import numpy as np |
| 5 | +import fidimag |
| 6 | +from fidimag.atomistic.energy import Energy |
| 7 | +import fidimag.extensions.fmm as fmm |
| 8 | +import time |
| 9 | +import sys |
4 | 10 |
|
5 | 11 |
|
6 | 12 | class Demag(Energy): |
@@ -41,7 +47,7 @@ def __init__(self, calc_every=0, name='Demag'): |
41 | 47 |
|
42 | 48 | def setup(self, mesh, spin, mu_s, mu_s_inv): |
43 | 49 | super(Demag, self).setup(mesh, spin, mu_s, mu_s_inv) |
44 | | - |
| 50 | + |
45 | 51 | # Ryan Pepper 04/04/2019 |
46 | 52 | # We *do not* need to scale by mesh.unit_length**3 here! |
47 | 53 | # This is because in the base energy class, dx, dy and dz |
@@ -94,3 +100,39 @@ def compute_energy(self): |
94 | 100 | self.energy /= self.scale |
95 | 101 |
|
96 | 102 | return energy / self.scale |
| 103 | + |
| 104 | + |
| 105 | +class DemagFMM(Energy): |
| 106 | + def __init__(self, order, ncrit, theta, name="DemagFMM", type='fmm'): |
| 107 | + self.type = type |
| 108 | + if self.type == 'fmm': |
| 109 | + self._type = 0 |
| 110 | + elif self.type == 'bh': |
| 111 | + self._type = 1 |
| 112 | + |
| 113 | + self.name = name |
| 114 | + assert order > 0, "Order must be 1 or higher" |
| 115 | + assert order < 11, "Order bust be < 11" |
| 116 | + self.order = order |
| 117 | + assert ncrit >= 2, "ncrit must be greater than 1." |
| 118 | + self.ncrit = ncrit |
| 119 | + assert theta >= 0.0, "theta must be >= 0.0" |
| 120 | + self.theta = theta |
| 121 | + |
| 122 | + def setup(self, mesh, spin, mu_s, mu_s_inv): |
| 123 | + super(DemagFMM, self).setup(mesh, spin, mu_s, mu_s_inv) |
| 124 | + self.coords = mesh.coordinates * mesh.unit_length |
| 125 | + self.m_temp = np.zeros_like(spin) |
| 126 | + self.fmm = fmm.FMM(self.n, self.ncrit, self.theta, |
| 127 | + self.order, |
| 128 | + self.coords, |
| 129 | + self.m_temp, |
| 130 | + self.mu_s, self._type |
| 131 | + ) |
| 132 | + |
| 133 | + def compute_field(self, t=0, spin=None): |
| 134 | + print('computing field') |
| 135 | + self.m_temp[:] = spin if spin is not None else self.spin |
| 136 | + self.fmm.compute_field(self.field) |
| 137 | + self.field *= -1e-7 |
| 138 | + return self.field |
0 commit comments