Skip to content
Snippets Groups Projects
Commit c04ce399 authored by Jan Caron's avatar Jan Caron
Browse files

Fixed source of warnings in analytic!

parent 14590e47
No related branches found
No related tags found
No related merge requests found
...@@ -164,8 +164,7 @@ def phase_mag_sphere(dim, a, phi, center, radius, b_0=1): ...@@ -164,8 +164,7 @@ def phase_mag_sphere(dim, a, phi, center, radius, b_0=1):
r = np.hypot(x - x0, y - y0) r = np.hypot(x - x0, y - y0)
result = coeff * R ** 3 / (r + 1E-30) ** 2 * ( result = coeff * R ** 3 / (r + 1E-30) ** 2 * (
(y - y0) * np.cos(phi) - (x - x0) * np.sin(phi)) (y - y0) * np.cos(phi) - (x - x0) * np.sin(phi))
# TODO: During testing: "RuntimeWarning: invalid value encountered in power": result *= 1 - np.clip(1 - (r / R) ** 2, 0, 1) ** (3. / 2.)
result *= np.where(r > R, 1, (1 - (1 - (r / R) ** 2) ** (3. / 2.)))
return result return result
# Process input parameters: # Process input parameters:
......
...@@ -111,6 +111,7 @@ class Kernel(object): ...@@ -111,6 +111,7 @@ class Kernel(object):
uu += prw_vec[1] uu += prw_vec[1]
vv += prw_vec[0] vv += prw_vec[0]
self.u[...] -= coeff * self._get_elementary_phase(geometry, uu, vv, a) self.u[...] -= coeff * self._get_elementary_phase(geometry, uu, vv, a)
# TODO: The minus sign belongs into the phasemapper (debatable)!
self.v[...] -= coeff * -self._get_elementary_phase(geometry, vv, uu, a) self.v[...] -= coeff * -self._get_elementary_phase(geometry, vv, uu, a)
# Calculate Fourier trafo of kernel components: # Calculate Fourier trafo of kernel components:
self.u_fft = fft.rfftn(self.u, self.dim_pad) self.u_fft = fft.rfftn(self.u, self.dim_pad)
...@@ -129,6 +130,7 @@ class Kernel(object): ...@@ -129,6 +130,7 @@ class Kernel(object):
def _get_elementary_phase(self, geometry, n, m, a): def _get_elementary_phase(self, geometry, n, m, a):
self._log.debug('Calling _get_elementary_phase') self._log.debug('Calling _get_elementary_phase')
# TODO: Rename n m to p q ?
if geometry == 'disc': if geometry == 'disc':
in_or_out = ~ np.logical_and(n == 0, m == 0) in_or_out = ~ np.logical_and(n == 0, m == 0)
return m / (n ** 2 + m ** 2 + 1E-30) * in_or_out return m / (n ** 2 + m ** 2 + 1E-30) * in_or_out
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment