-
Notifications
You must be signed in to change notification settings - Fork 9
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
[Feature request] ROI specific exports #3
Comments
@PeerHerholz - do you mean to separate out the labels into different roi files? i think that part is relatively easy to do with a few lines of nibabel code, so didn't put it in this wrapper. however if you mean different parcellations, one should be able to use the existing model on more specific datasets to learn different parcels. perhaps @kaczmarj can lend a hand. more generally though we are hoping to transition the codebase to nobrainer 2.0, which should make retraining and transfer learning a lot easier. |
@satra, somewhat both.
Yeah, that's what I thought, rather straightforward to implement (maybe also a nice fit for
That sounds great and I would be happy to help out. I'll give it a try with the current model and let you know. Do you have any idea/ideas/insights on possible differences wrt performance/fit between whole brain and e.g. lobe only parcellations? |
hi @PeerHerholz - i would be happy to help you with the nibabel code if you'd like.
the current model was trained to label 32x32x32 voxel volumes. we predict on whole brains by separating the volume into non-overlapping blocks of 32x32x32. the volumes should have 1mm^3 voxel sizes. to predict on part of a brain (i.e., not whole-brain), one could take part of the whole volume, separate that into 32x32x32 non-overlapping blocks, predict, and put back together the non-overlapping blocks. does that make sense? using that procedure, the predictions will take less time because there is less data. what do you mean by "fit"? the accuracy of the predictions should be just as good for lobe only parcellations compared to whole-brain parcellations. if you were to use the mean of the variational weights, the predictions should in fact be identical. |
Ahoi hoi @kaczmarj, thx for following up on this.
Yeah, happy to work with you on that. Any idea where we should place that sort of functionality, in terms of repo, etc.?
Check, although I'm not entirely sure on how to implement that. Let's say I only want to parcellate the temporal lobe based on the corresponding learned parcellation. How would my workflow look like? Sorry for being off here.
Oh yeah, you're right. |
depending on how the roi separation functionality is implemented, this could go in this repo or some other place. i think that separating out the labels into different files would be the best (read easiest) way to go. i think i went a little overboard in an earlier comment suggesting that we could predict on a subset of the brain in 32x32x32 blocks. all i wanted to convey here is that in theory, you could feed the network any 32x32x32 voxel block from a scan and it will give you labels. so you could feed it blocks from your rois, and it will give you labels for those rois. i think it would be much easier to predict on the whole brain and then extract the labels in your rois. i realized that the mapping between the model's output (the integer values) and anatomical names might not be clear. i have created a list below of the structures that each label should represent. if you want to include only certain labels, then you can mask the numpy arrays. let's say you want to extract only caudate and putamen: # means is the numpy array of the model predictions
mask = ~np.isin(means, [6, 7])
# zero everything except caudate and putamen predictions
means[mask] = 0
variance[mask] = 0
entropy[mask] = 0 is this the behavior you want? or am i misunderstanding?
|
@kaczmarj - it may be worthwhile to add a conversion back to freesurfer scheme step at the end of the kwyk inference. this would likely require going label by label and using it may be worthwhile retraining kwyk with at least one, if not all separated left and right labels, given that we have access to a lot more scans at this point. |
Yes, exactly. Thx for the clarification. I think the possible back-to-freesurfer-scheme step would be great and useful. Couldn't the necessary steps be integrated with the discussed functionality to break the parcellation into the respective ROIs (and files) as those could then be assembled again accordingly? Re retraining the network: I was about to ask if you also have other parcellations that kwyk could be/was trained on (e.g., Destrieux)? |
Hi,
I was just wondering if ROI specific functionality/exports might be a nice feature or outside
the scope of the project? E.g., let's say I only want to have and compare auditory cortex ROIs.
Cheers, Peer
The text was updated successfully, but these errors were encountered: