-
Notifications
You must be signed in to change notification settings - Fork 7
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
BEP016: Forced data representation specification #67
Conversation
For what are currently referred to as "model fit parameters", make it REQUIRED to specify metadata field "OrientationRepresentation".
Codecov Report
@@ Coverage Diff @@
## bep-016 #67 +/- ##
========================================
Coverage 88.53% 88.53%
========================================
Files 6 6
Lines 1055 1055
========================================
Hits 934 934
Misses 121 121 Help us with your feedback. Take ten seconds to tell us how you rate us. Have a feature suggestion? Share it here. |
This is interesting. I'm wondering whether there aren't cases of things that are not model-fit parameters that also need the |
There absolutely are: fibre orientations could be an mfp in the case of ball-and-sticks, or an mdp in the case pf spherical deconvolution. This is wholly supported by the BEP as it currently stands. The specific distinction I'm contemplating here is the case of simple scalar images: in the case of an mdp, it would be most convenient to not be forced to specify " |
Thanks for the clarification. Do I understand correctly that this only matters for cases of things that could have a singleton last dimension then? Is it really just the lmax=0 sh images? The ball and stick examples don't seem to fit this. |
I can't really figure out exactly what the question is; there's too many "the"'s and "this"'s and "it"'s. But I'll opine a bit more and see if anything helps it to stick. For anything that does contain orientation information, that metadata field will always be compulsory. For any 4D image with more than one volume, it is impossible to determine from the image size alone what type of orientation data is encoded. For instance, if you have an image with six volumes, it could be:
If you now reduce to the 3D image case, there's still a potential ambiguity: it could be a scalar image, or it could be an SH image with l=0 (and the limitations of NIfTI precludes us from telling the difference through image dimensionality). Therefore, the safest approach is to demand that the nature of the data representation always be explicitly defined. But if someone just wants to take a tensor fit and generate an FA image, it may be difficult to explain to them that they have to explicitly state that that image is a scalar map, as opposed to something else. It's far from intuitive as to why that would be necessary. My point here is: If you wanted to relax the restriction on having to always explicitly state that data representation for every image, one way in which you might define the scenario in which you permit its absence would be:
The reason this is relevant for the discussion during the BIDS Connectivity workshop is that point 2 provides a plausible scenario under which having a suffix-based distinction between model fit parameters and model-derived parameters is of utility. |
OK. What I understand so far: The Is that correct? Another approach would be to assume that 3D model parameters (whether fit or derived) is scalar unless otherwise specified in the metadata. Would that fail for any of your use-cases? Maybe that's easier to explain? |
Correct and correct. Again, I'm not actually saying that this is something I want to adopt. For instance, one could follow your second suggestion, and say that anything with three non-singleton dimensions is a scalar unless one explicitly sets " |
Yes -- I am increasingly convinced that a distinction between model-fit parameters and model-derived parameters would not buy us much and is often mired in ambiguity. |
I think the comment above may be intended for a different issue thread; likely #69. I would note that as per my last comment in #68, if the |
My comment certainly relates to #69, but it was more of a reply to this specific sentence:
I continue to be skeptical that this distinction will prove useful -- this specific issue being a case in point. And yes, we can continue discussing in #68. The |
FYI I'm leaning in this direction myself. In my own head I find it an important distinction, but in the context of a discrete BIDS App generating a finite set of derivatives, ie. the user is not responsible for the progression of fitting a model and then deriving parameters from the model, it largely loses its function. If this is the best exemplar justification I can some up with for it, it's probably a losing argument. If this distinction is removed, the discussion in this PR remains relevant in that we must decide if there is any circumstance in which, for anything with the relevant suffix (eg. " |
This argument makes sense to me:
So, I think the rule should be that a file with a |
As an aside, should we already start using macros for the tables? Might be a topic for a separate issue. |
From a conceptual viewpoint, not at all. But I have precisely zero knowledge of the internal operation of the validator to know what is or is not difficult to validate. In this particular scenario, the validator would need to be able to read NIfTI headers and attribute dimensionality based on the axis sizes (since NIfTI doesn't store dimensionality explicitly, it relies on interpreting trailing axes of unary size). No idea if it reads NIfTI headers at all elsewhere. |
Closed due to being superseded by #92. |
Thought that came to me this morning regarding the distinction between what are currently referred to as "model fit parameters" and "model-derived parameters".
Consider models that provide a combination of isotropic and anisotropic data. Examples might include:
FSL bedpostx ball-and-sticks, which has both discrete fibre orientations in spherical coordinates and voxel-wise scalar values such as mean & standard deviation of diffusivity.
MRtrix3 MSMT CSD, which provides multiple spherical harmonics images. Under typical usage there is one such image with lmax > 0 (ie. anisotropic) and multiple other images with lmax = 0 (ie. isotropic). However the latter of these are not scalar images; they are still spherical harmonic images, which therefore include a sqrt(4pi) scaling due to the spherical harmonic basis.
One might therefore consider the prospect that, for model fit parameters, it should be compulsory that metadata field "
OrientationRepresentation
" be specified. This is in part because in NIfTI it is not possible to distinguish between an image with dimensions X x Y x Z and one with dimensions X x Y x Z x 1; the latter would be reasonably interpreted as an SH image whereas the former is not. Regardless, forcing this field to be present would provide an unambiguous distinction between these two cases, which would be self-contained and not dependent on the contents of any other files.Now consider instead a model-derived parameter such as FA. Obviously this is a scalar image. However making it compulsory to specify "
"OrientationRepresentation": "scalar"
" in the sidecar of such an image would seem an unusual demand. So permitting the inference of being a scalar representation in the case of a 3D image with noOrientationRepresentation
field would, to me, be more reasonable in the model-derived parameter case than it would for the model fit parameter case.This PR is flagged as draft: