mrpro.operators.CartesianSamplingOp
- class mrpro.operators.CartesianSamplingOp[source]
Bases:
LinearOperator
Cartesian Sampling Operator.
Selects points on a Cartesian grid based on the k-space trajectory. Thus, the adjoint sorts the data into regular Cartesian sampled grid based on the k-space trajectory. Non-acquired points are zero-filled.
- __init__(encoding_matrix: SpatialDimension[int], traj: KTrajectory) None [source]
Initialize Sampling Operator class.
- Parameters:
encoding_matrix (
SpatialDimension
[int
]) – shape of the encoded k-space. Only values for directions in which the trajectory is Cartesian will be used in the adjoint to determine the shape after reordering, i.e., the operator’s domain.traj (
KTrajectory
) – the k-space trajectory describing at which frequencies data is sampled. Its broadcasted shape will be used to determine the shape after sampling, i.e., the operator’s range.
- property gram: CartesianSamplingGramOp[source]
Return the Gram operator for this Cartesian Sampling Operator.
- Returns:
Gram operator for this Cartesian Sampling Operator.
- property H: LinearOperator[source]
Adjoint operator.
Obtains the adjoint of an instance of this operator as an
AdjointLinearOperator
, which itself is a anLinearOperator
that can be applied to tensors.Note:
linear_operator.H.H == linear_operator
- __call__(*args: Unpack) Tout [source]
Apply the forward operator.
For more information, see
forward
.
- adjoint(y: Tensor) tuple[Tensor] [source]
Adjoint operator sorting data into the encoding_space matrix.
- Parameters:
y (
Tensor
) – k-space data in acquired shape- Returns:
K-space data sorted into encoding_space matrix.
- forward(x: Tensor) tuple[Tensor] [source]
Forward operator which selects acquired k-space data from k-space.
- Parameters:
x (
Tensor
) – k-space, fully sampled (or zerofilled) and sorted in Cartesian dimensions with shape given by encoding_matrix- Returns:
Selected k-space data in acquired shape (as described by the trajectory).
- operator_norm(initial_value: Tensor, dim: Sequence[int] | None, max_iterations: int = 20, relative_tolerance: float = 1e-4, absolute_tolerance: float = 1e-5, callback: Callable[[Tensor], None] | None = None) Tensor [source]
Power iteration for computing the operator norm of the operator.
- Parameters:
initial_value (
Tensor
) – initial value to start the iteration; must be element of the domain. if the initial value contains a zero-vector for one of the considered problems, the function throws anValueError
.The dimensions of the tensors on which the operator operates. The choice of
dim
determines how the operator norm is inperpreted. For example, for a matrix-vector multiplication with a batched matrix tensor of shape(batch1, batch2, row, column)
and a batched input tensor of shape(batch1, batch2, row)
:If
dim=None
, the operator is considered as a block diagonal matrix with batch1*batch2 blocks and the result is a tensor containing a single norm value (shape(1, 1, 1)
).If
dim=(-1)
,batch1*batch2
matrices are considered, and for each a separate operator norm is computed.If
dim=(-2,-1)
,batch1
matrices withbatch2
blocks are considered, and for each matrix a separate operator norm is computed.
Thus, the choice of
dim
determines implicitly determines the domain of the operator.max_iterations (
int
, default:20
) – maximum number of iterationsrelative_tolerance (
float
, default:1e-4
) – absolute tolerance for the change of the operator-norm at each iteration; if set to zero, the maximal number of iterations is the only stopping criterion used to stop the power iteration.absolute_tolerance (
float
, default:1e-5
) – absolute tolerance for the change of the operator-norm at each iteration; if set to zero, the maximal number of iterations is the only stopping criterion used to stop the power iteration.callback (
Callable
[[Tensor
],None
] |None
, default:None
) – user-provided function to be called at each iteration
- Returns:
An estimaton of the operator norm. Shape corresponds to the shape of the input tensor
initial_value
with the dimensions specified indim
reduced to a single value. The pointwise multiplication ofinitial_value
with the result of the operator norm will always be well-defined.
- __add__(other: LinearOperator | Tensor) LinearOperator [source]
- __add__(other: Operator[Tensor, tuple[Tensor]]) Operator[Tensor, tuple[Tensor]]
Operator addition.
Returns
lambda x: self(x) + other(x)
if other is a operator,lambda x: self(x) + other
if other is a tensor
- __and__(other: LinearOperator) LinearOperatorMatrix [source]
Vertical stacking of two LinearOperators.
A&B
is aLinearOperatorMatrix
with two rows, with(A&B)(x) == (A(x), B(x))
. Seemrpro.operators.LinearOperatorMatrix
for more information.
- __matmul__(other: LinearOperator) LinearOperator [source]
- __matmul__(other: Operator[Unpack, tuple[Tensor]]) Operator[Unpack, tuple[Tensor]]
Operator composition.
Returns
lambda x: self(other(x))
- __mul__(other: Tensor | complex) LinearOperator [source]
Operator elementwise left multiplication with tensor/scalar.
Returns
lambda x: self(x*other)
- __or__(other: LinearOperator) LinearOperatorMatrix [source]
Horizontal stacking of two LinearOperators.
A|B
is aLinearOperatorMatrix
with two columns, with(A|B)(x1,x2) == A(x1)+B(x2)
. Seemrpro.operators.LinearOperatorMatrix
for more information.
- __radd__(other: Tensor) LinearOperator [source]
Operator addition.
Returns
lambda x: self(x) + other*x
- __rmul__(other: Tensor | complex) LinearOperator [source]
Operator elementwise right multiplication with tensor/scalar.
Returns
lambda x: other*self(x)