Commit 68908d7c authored by Pumpe, Daniel (dpumpe)'s avatar Pumpe, Daniel (dpumpe)
Browse files

Torsten asked me to incorporate a typical resonse operator (incl. convolution...

Torsten asked me to incorporate a typical resonse operator (incl. convolution and exposure) projecting into geometrically not ordered spaces (such as point space)
parent 394f8110
......@@ -38,3 +38,5 @@ from projection_operator import ProjectionOperator
from propagator_operator import PropagatorOperator
from composed_operator import ComposedOperator
from response_operator import ResponseOperator
from response_operator import ResponseOperator
from nifty import Field,\
import numpy as np
class ResponseOperator(LinearOperator):
def __init__(self, domain,
sigma=1., exposure=1., implemented=True,
self._domain = self._parse_domain(domain)
self._target = self._parse_domain(FieldArray(self._domain[0].shape,
self._sigma = sigma
self._implemented = implemented
self._unitary = unitary
self._kernel = SmoothingOperator(self._domain,
self._exposure = exposure
def domain(self):
return self._domain
def target(self):
return self._target
def implemented(self):
return self._implemented
def unitary(self):
return self._unitary
def _times(self, x, spaces):
res = self._kernel.times(x)
res = self._exposure * res
return Field(self._target, val=res.val)
def _adjoint_times(self, x, spaces):
# setting correct spaces
res = x*self._exposure
res = Field(self.domain, val=res.val)
res = res.weight(power=-1)
res = self._kernel.adjoint_times(res)
return res
Markdown is supported
0% or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment