Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[SCHEMA] Define YAML tables for MRI common metadata fields and anatomy data #1017

Merged
merged 6 commits into from
Mar 17, 2022
Merged
Changes from 5 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
221 changes: 210 additions & 11 deletions src/schema/rules/sidecars.yml
Original file line number Diff line number Diff line change
Expand Up @@ -6,9 +6,10 @@


---
# MRI Common metadata fields
MRIScannerHardware:
selectors:
- modality == "MRI"
- modality == "MRI"
fields:
Manufacturer:
level: RECOMMENDED
Expand Down Expand Up @@ -37,15 +38,16 @@ MRIScannerHardware:

MRISequenceSpecifics:
selectors:
- modality == "MRI"
- modality == "MRI"
fields:
PulseSequenceType: RECOMMENDED
ScanningSequence: RECOMMENDED
SequenceVariant: RECOMMENDED
ScanOptions: RECOMMENDED
SequenceName: RECOMMENDED
PulseSequenceDetails: RECOMMENDED
NonlinearGradientCorrection: RECOMMENDED, but REQUIRED if [PET](./09-positron-emission-tomography.md) data are present
NonlinearGradientCorrection: |
RECOMMENDED, but REQUIRED if [PET](./09-positron-emission-tomography.md) data are present
MRAcquisitionType: RECOMMENDED, but REQUIRED for Arterial Spin Labeling
MTState: RECOMMENDED
MTOffsetFrequency: OPTIONAL
Expand All @@ -61,21 +63,21 @@ MRISequenceSpecifics:

PETMRISequenceSpecifics:
selectors:
- modality == "MRI"
- "PET" in dataset.modalities
Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Having quotes around PET causes syntax error: expected <block end>, but found '<scalar>' (syntax)

- modality == "MRI"
- PET in dataset.modalities
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

What about the inverse?

Suggested change
- PET in dataset.modalities
- dataset.modalities contains "PET"

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

That works for me.

fields:
NonLinearGradientCorrection: REQUIRED

ASLMRISequenceSpecifics:
selectors:
- modality == "MRI"
- datatype == "perf"
- modality == "MRI"
- datatype == "perf"
fields:
MRAcquisitionType: REQUIRED

MTParameters:
selectors:
- sidecar.MTState == True
- sidecar.MTState == True
fields:
MTOffsetFrequency: RECOMMENDED
MTPulseBandwidth: RECOMMENDED
Expand All @@ -85,19 +87,216 @@ MTParameters:

SpoilingType:
selectors:
- sidecar.SpoilingState == True
- sidecar.SpoilingState == True
fields:
SpoilingType: RECOMMENDED

SpoilingRF:
selectors:
- sidecar.SpoilingType in ["RF", "COMBINED"]
- sidecar.SpoilingType in ["RF", "COMBINED"]
fields:
SpoilingRFPhaseIncrement: RECOMMENDED

SpoilingGradient:
selectors:
- sidecar.SpoilingType in ["GRADIENT", "COMBINED"]
- sidecar.SpoilingType in ["GRADIENT", "COMBINED"]
fields:
SpoilingGradientMoment: RECOMMENDED
SpoilingGradientDuration: RECOMMENDED

MRISpatialEncoding:
selectors:
- modality == "MRI"
fields:
NumberShots: RECOMMENDED
ParallelReductionFactorInPlane: RECOMMENDED
ParallelAcquisitionTechnique: RECOMMENDED
PartialFourier: RECOMMENDED
PartialFourierDirection: RECOMMENDED
PhaseEncodingDirection:
level: RECOMMENDED
level_addendum: |
This parameter is REQUIRED if corresponding fieldmap data is present
or when using multiple runs with different phase encoding directions
(which can be later used for field inhomogeneity correction).
EffectiveEchoSpacing:
level: RECOMMENDED
level_addendum: |
<sup>2</sup> This parameter is REQUIRED if corresponding fieldmap data
is present.
TotalReadoutTime:
level: RECOMMENDED
level_addendum: |
<sup>3</sup> This parameter is REQUIRED if corresponding 'field/distortion' maps
acquired with opposing phase encoding directions are present
(see [Case 4: Multiple phase encoded
directions](#case-4-multiple-phase-encoded-directions-pepolar)).
MixingTime: RECOMMENDED

MRITimingParameters:
selectors:
- modality == "MRI"
fields:
EchoTime:
level: RECOMMENDED
level_addendum: |
REQUIRED if corresponding fieldmap data is present,
or the data comes from a multi-echo sequence or Arterial Spin Labeling.
InversionTime: RECOMMENDED
SliceTiming:
level: RECOMMENDED
level_addendum: |
REQUIRED for sparse sequences that do not have the `DelayTime` field set,
and Arterial Spin Labeling with `MRAcquisitionType` set on `2D`.
SliceEncodingDirection: RECOMMENDED
DwellTime: RECOMMENDED

SliceTimingASL:
selectors:
- modality == "MRI"
- datatype == "perf"
- suffix in ["asl", "m0scan"]
- sidecar.MRAcquisitionType == "2D"
fields:
SliceTiming: REQUIRED

# This is technically for sparse sequences only, but I don't know how to encode that.
SliceTimingSparse:
selectors:
- modality == "MRI"
- sidecar.DelayTime isDefined
Copy link
Collaborator

@effigies effigies Mar 10, 2022

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Just a thought:

Suggested change
- sidecar.DelayTime isDefined
- sidecar contains "DelayTime"

Or maybe

Suggested change
- sidecar.DelayTime isDefined
- defined(sidecar.DelayTime)

fields:
SliceTiming: REQUIRED

MRIRFandContrast:
selectors:
- modality == "MRI"
fields:
FlipAngle:
level: RECOMMENDED
level_addendum: REQUIRED if LookLocker is set to `true`.
NegativeContrast: OPTIONAL

MRIFlipAngleLookLocker:
selectors:
- modality == "MRI"
- sidecar.LookLocker == True
fields:
FlipAngle: REQUIRED

MRISliceAcceleration:
selectors:
- modality == "MRI"
fields:
MultibandAccelerationFactor: RECOMMENDED

MRIAnatomicalLandmarks:
selectors:
- modality == "MRI"
fields:
AnatomicalLandmarkCoordinates__mri: RECOMMENDED

MRIEchoPlanarImagingAndB0Mapping:
selectors:
- modality == "MRI"
fields:
B0FieldIdentifier: RECOMMENDED
B0FieldSource: RECOMMENDED

MRIInstitutionInformation:
selectors:
- modality == "MRI"
fields:
InstitutionName:
level: RECOMMENDED
addendum: Corresponds to DICOM Tag 0008, 0080 `InstitutionName`.
InstitutionAddress:
level: RECOMMENDED
addendum: Corresponds to DICOM Tag 0008, 0081 `InstitutionAddress`.
InstitutionalDepartmentName:
level: RECOMMENDED
addendum: Corresponds to DICOM Tag 0008, 1040 `Institutional Department Name`.

# Anatomy imaging data

MRIAnatomyCommonMetadataFields:
selectors:
- modality == "MRI"
- datatype == "anat"
fields:
ContrastBolusIngredient: OPTIONAL
RepetitionTimeExcitation: OPTIONAL
RepetitionTimePreparation: OPTIONAL

# Entities
Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I added these because they weren't covered in #1014, but I'm not sure if they should go in this file.

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This feels like it should be its own file, but it does need to be highest priority.

Only issue I'm seeing is that these will correspond to data files, and not, say, an events.tsv.


EntitiesTaskMetadata:
selectors:
- entities.task isDefined
fields:
TaskName: RECOMMENDED

EntitiesCeMetadata:
selectors:
- entities.ce isDefined
fields:
ContrastBolusIngredient: OPTIONAL

EntitiesTrcMetadata:
selectors:
- entities.trc isDefined
fields:
TracerName: REQUIRED

EntitiesStainMetadata:
selectors:
- entities.stain isDefined
fields:
SampleStaining: RECOMMENDED
SamplePrimaryAntibodies: RECOMMENDED
SampleSecondaryAntibodies: RECOMMENDED

EntitiesEchoMetadata:
selectors:
- entities.echo isDefined
fields:
EchoTime: REQUIRED

EntitiesFlipMetadata:
selectors:
- entities.flip isDefined
fields:
FlipAngle: REQUIRED

EntitiesInvMetadata:
selectors:
- entities.inv isDefined
fields:
InversionTime: REQUIRED

EntitiesMTMetadata:
selectors:
- entities.mt isDefined
fields:
MTState: REQUIRED

EntitiesPartMetadata:
selectors:
- entities.part == "phase"
fields:
Units:
level: REQUIRED
rules:
- value in ["rad", "arbitrary"]

EntitiesResMetadata:
selectors:
- entities.res isDefined
fields:
Resolution: REQUIRED

EntitiesDenMetadata:
selectors:
- entities.den isDefined
fields:
Density: REQUIRED