Spike
Bases: IntensityTransform
Add random MRI spike artifacts.
Also known as herringbone artifact, crisscross artifact, or corduroy artifact. Spikes in k-space create stripes in image space.
The artifact is simulated by adding point impulses to the Fourier
spectrum of the image. All operations use torch.fft and run
on GPU.
Parameters:
| Name | Type | Description | Default |
|---|---|---|---|
num_spikes
|
int | tuple[int, int]
|
Number of spikes. A scalar \(n\) is deterministic; a 2-tuple \((a, b)\) samples \(n \sim \mathcal{U}(a, b) \cap \mathbb{N}\). |
1
|
intensity
|
float | tuple[float, float]
|
Ratio between the spike amplitude and the spectrum
maximum. A scalar is deterministic; a 2-tuple \((a, b)\)
means \(r \sim \mathcal{U}(a, b)\).
The default |
0.0
|
**kwargs
|
Any
|
See |
{}
|
Note
Execution time does not depend on the number of spikes.
Examples:
>>> import torchio as tio
>>> transform = tio.Spike(intensity=2.0)
>>> transform = tio.Spike(num_spikes=3, intensity=2.0)
Source code in src/torchio/transforms/intensity/spike.py
16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 | |
invertible
property
Whether this transform can be inverted.
forward(data)
Apply the transform.
The output type always matches the input type.
Parameters:
| Name | Type | Description | Default |
|---|---|---|---|
data
|
Any
|
Input data to transform. |
required |
Source code in src/torchio/transforms/transform.py
inverse(params)
Return a transform that undoes this one.
Override in invertible subclasses. The returned transform, when applied, reverses the effect of the forward pass with the given parameters.
Parameters:
| Name | Type | Description | Default |
|---|---|---|---|
params
|
dict[str, Any]
|
The parameters recorded in the forward pass. |
required |
Returns:
| Type | Description |
|---|---|
Transform
|
A new |
Source code in src/torchio/transforms/transform.py
to_hydra()
Export as a Hydra-compatible config dict.
Returns a dict with _target_ set to the fully qualified
class name and only non-default field values included.
Returns:
| Type | Description |
|---|---|
dict[str, Any]
|
Dict suitable for |
Source code in src/torchio/transforms/transform.py
make_params(batch)
Sample the number and positions of spikes (per element when batched).
Source code in src/torchio/transforms/intensity/spike.py
apply_transform(batch, params)
Add spike artifacts to each selected image.