WIP cython wrappers for plane waves in scatsys

Former-commit-id: 42cf85afc93e9cc63291b7030a7129a21e098826
This commit is contained in:
Marek Nečada 2019-07-15 16:36:37 +03:00
parent ebefc07e9d
commit 911f6b758c
3 changed files with 41 additions and 1 deletions

View File

@ -1582,6 +1582,7 @@ cdef class ScatteringSystem:
ar_view[pi] = self.s[0].tm[self.s[0].p[pi].tmatrix_id].spec[0].n ar_view[pi] = self.s[0].tm[self.s[0].p[pi].tmatrix_id].spec[0].n
return ar return ar
def fullvec_poffsets(self): def fullvec_poffsets(self):
cdef np.ndarray[intptr_t, ndim=1] ar = np.empty((self.s[0].p_count,), dtype=np.intp) cdef np.ndarray[intptr_t, ndim=1] ar = np.empty((self.s[0].p_count,), dtype=np.intp)
cdef intptr_t[::1] ar_view = ar cdef intptr_t[::1] ar_view = ar
@ -1600,6 +1601,25 @@ cdef class ScatteringSystem:
ar_view[pi,2] = self.s[0].p[pi].pos.z ar_view[pi,2] = self.s[0].p[pi].pos.z
return ar return ar
def planewave_full(self, k_cart, E_cart):
if k_cart.shape != (3,) or E_cart.shape != (3,):
raise ValueError("k_cart and E_cart must be ndarrays of shape (3,)")
cdef qpms_incfield_planewave_params_t p
p.use_cartesian = 1
p.k.cart.x = <cdouble>k_cart[0]
p.k.cart.y = <cdouble>k_cart[1]
p.k.cart.z = <cdouble>k_cart[2]
p.E.cart.x = <cdouble>E_cart[0]
p.E.cart.y = <cdouble>E_cart[1]
p.E.cart.z = <cdouble>E_cart[2]
cdef np.ndarray[np.complex_t, ndim=1] target_np = np.empty(
(self.fecv_size,), dtype=complex)
cdef cdouble[::1] target_view = target_np
qpms_scatsys_incident_field_vector_full(&target_view[0],
self.s, qpms_incfield_planewave, <void *>&p, 0)
return target_np
def tlm2uvswfi(t, l, m): def tlm2uvswfi(t, l, m):
''' TODO doc ''' TODO doc
And TODO this should rather be an ufunc. And TODO this should rather be an ufunc.

View File

@ -9,6 +9,10 @@ cdef extern from "qpms_types.h":
double x double x
double y double y
double z double z
cdef struct ccart3_t:
cdouble x
cdouble y
cdouble z
cdef struct cart2_t: cdef struct cart2_t:
double x double x
double y double y
@ -100,6 +104,19 @@ cdef extern from "qpms_error.h":
qpms_dbgmsg_flags qpms_dbgmsg_enable(qpms_dbgmsg_flags types) qpms_dbgmsg_flags qpms_dbgmsg_enable(qpms_dbgmsg_flags types)
qpms_dbgmsg_flags qpms_dbgmsg_disable(qpms_dbgmsg_flags types) qpms_dbgmsg_flags qpms_dbgmsg_disable(qpms_dbgmsg_flags types)
cdef extern from "vswf.h":
ctypedef qpms_errno_t (*qpms_incfield_t)(cdouble target, const qpms_vswf_set_spec_t *bspec,
const cart3_t evalpoint, const void *args, bint add)
ctypedef struct qpms_incfield_planewave_params_t:
bint use_cartesian
union k:
ccart3_t cart
csph_t sph
union E:
ccart3_t cart
csph sph
qpms_errno_t qpms_incfield_planewave(cdouble target, const qpms_vswf_set_spec_t *bspec,
const cart3_t evalpoint, const void *args, bint add)
cdef extern from "indexing.h": cdef extern from "indexing.h":
qpms_uvswfi_t qpms_tmn2uvswfi(qpms_vswf_type_t t, qpms_m_t m, qpms_l_t n) qpms_uvswfi_t qpms_tmn2uvswfi(qpms_vswf_type_t t, qpms_m_t m, qpms_l_t n)
@ -342,6 +359,9 @@ cdef extern from "scatsystem.h":
cdouble *target, const qpms_scatsys_t *ss, qpms_iri_t iri, double k) cdouble *target, const qpms_scatsys_t *ss, qpms_iri_t iri, double k)
cdouble *qpms_scatsys_build_modeproblem_matrix_irrep_packed_parallelR( cdouble *qpms_scatsys_build_modeproblem_matrix_irrep_packed_parallelR(
cdouble *target, const qpms_scatsys_t *ss, qpms_iri_t iri, double k) nogil cdouble *target, const qpms_scatsys_t *ss, qpms_iri_t iri, double k) nogil
cdouble *qpms_scatsys_incident_field_vector_full(cdouble *target_full,
const qpms_scatsys_t *ss, qpms_incfield_t field_at_point,
const void *args, bint add)

View File

@ -77,7 +77,7 @@ csphvec_t qpms_eval_uvswf(const qpms_vswf_set_spec_t *setspec,
// --- qpms_incfield_t instances and their arguments // --- qpms_incfield_t instances and their arguments
/// Parameter structure for qpms_incfield_planewave() /// Parameter structure for qpms_incfield_planewave()
typedef struct qpms_incfield_planewane_params_t { typedef struct qpms_incfield_planewave_params_t {
bool use_cartesian; ///< If true, wave direction k and amplitude E are specified in cartesian coordinates (via k.cart, E.cart). If false, k is specified in spherical coordinates and E are specified in the corresponding geographical coordinates (via k.sph, E.sph). bool use_cartesian; ///< If true, wave direction k and amplitude E are specified in cartesian coordinates (via k.cart, E.cart). If false, k is specified in spherical coordinates and E are specified in the corresponding geographical coordinates (via k.sph, E.sph).
union { union {
ccart3_t cart; ccart3_t cart;