SSFP simulation

## SSFP

Simple steady-state free precession simulation. The goal is to provide a simple to use, pip-installable solution for simulating and working with this wonderful pulse sequence.

In this package:

• bSSFP: bssfp()
• GS solution: gs_recon()
• PLANET: planet()
• 3D Region Growing Phase Correction: rgphcorr3d()
• Robust Coil Combination: robustcc()

## Installation

Should be as easy as:

```pip install ssfp
```

## Usage

See ssfp.examples for typical usage. You can run examples like:

```python -m ssfp.examples.basic_bssfp
```

Balanced steady-state free precession can be called through bssfp(). This is an implementation of equations [1–2] in . These equations are based on the Ernst-Anderson derivation  where off-resonance is assumed to be subtracted as opposed to added (as in the Freeman-Hill derivation ). Hoff actually gets Mx and My flipped in the paper, so we fix that here. We also assume that the field map will be provided given the Freeman-Hill convention.

```from ssfp import bssfp

# Here's the simplest usage, see docstring for all the possible
# function arguments
sig = bssfp(T1, T2, TR, alpha)
```

We can also easily get the Geometric Solution to the elliptical signal model as described in  as follows:

```from ssfp import gs_recon
recon = gs_recon(phased_cycled_images, pc_axis=-1)

# Notice that we can specify the axis where the phase-cycles live
```

PLANET  is a method for simultaneous T1, T2 fitting for bSSFP phase-cycled data. Call like this:

```from ssfp import planet

# For a single pixel:
Meff, T1, T2, df = planet(
phased_cycled_pixels, alpha, TR, T1_guess,
```

3D Region Growing Phase Correction  is an algorithm for determining water and fat images from a single bSSFP acquisition. It can be called like this:

```from ssfp import rgphcorr3d
phase_corrected = rgphcorr3d(
dataset3d, cellsize=(4, 4, 4), slice_axis=-1)

# see ssfp.examples.basic_rgphcorr for full usage example
```

Robust Coil Combination for bSSFP Elliptical Signal Model  is a coil combination method that preserves the elliptical relationships between phase-cycled pixels. It has two variants: simple and full. By default, the simple method is called. The full method is very slow and only used for validation of the simple method. Robust coil combination can be called like this:

```from ssfp import robustcc

sx, sy, sz, num_pc, num_coils = data.shape[:]
coil_combined = robustcc(data, pc_axis=-2, coil_axis=-1)

# see ssfp.examples.basic_robustcc for more usage examples
```

# Changelog

• 1.0.0: bssfp() function overhaul to allow arbitrarily dimensioned input arrays or scalars and removes the target_pc_axis argument.

## Project details

This version 1.0.0 0.6.0 0.5.0 0.4.2 0.4.1 0.4.0 0.3.0 0.2.0 0.1.0 0.0.1

Uploaded `source`
Uploaded `py3`