-
Notifications
You must be signed in to change notification settings - Fork 18
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
Miccai/Oasis Label Set Progress and Questions #15
Comments
Some of the ROIs on the medial wall are creeping onto the opposite hemisphere, too. Have to figure out how to reassign those voxels. |
Was able to install V8 with help from the package creators. |
Hi @butellyn ! Thanks for being so thorough and keeping us posted on your progress. If it helps, this is as far as I also got with this procedure. My maps looked a little less holey, but all-in-all much the same. I have an idea though of how to improve it, though. Unfortunately, an untimely necessary formating of my hard-drive made me loose the work I had done on getting the functions in R working (stupid me for not pushing to github). I am pretty close to recreating the work, and the functions are almost working again. After the conference, I will work more on them, and share with you my progress and we can have a discussion on how we can improve your atlas. |
Oh no! Looking forward to brainstorming more! A PI in my lab suggested dilating the labels, which helped a lot: Now the labels that are on the medial wall that were bleeding over to the opposite hemisphere are more apparent, though. Do you know how to combine two labels? Aesthetically, it would be nice to smooth out the edges so that they aren't so jagged. And then at least two labels are mysteriously missing (lh_LiG, rh_IoG). Looking into that now. |
So it turns out the missing labels has something to do with the kernel. When I changed it to 2, no regions where missing on the left hemisphere, but there are more gaps than desirable. The right hemisphere still had at least one missing label: I ended up deleting the labels that bled across hemispheres. It makes the edges of the images a little jagged, but it's better than the alternative. Would be nice to figure out how to fix this. Here's what the (tentative) figure looks like! |
A senior research scientist in my lab suggested using ImageMath from ANTs PropagateLabelsThroughMask to fix the holes. I will try this as soon as I manage to compile ANTs on my local computer. |
Hi @butellyn ! Very happy you're keeping us update on your progress. I'm sorry I'm not as active as I'd like in this, but we are both of us very much swamped in other work at the moment. I hope to get a respite soon so I can follow you up on this. I think the tentative figure is looking very promising. |
@Athanasiamo, have you had a chance to look into this? I'd love to close these gaps very soon, if possible. If not, I can catch it on revisions. |
Hi @butellyn! I have looked at it, but not yet made any real progress. But I am finding very little time to spend on this at the moment, with other pressing issues. I give it a go every once in a while and make small steps, but not to the extent I'd like to! |
Hi @butellyn ! Sorry for the lateness of this, but we have finally made a workflow that seems to work well for cortical parcellations. The workflow is quite different, but is done mainly through R (as long as other software is on your system) and should work well. We found that working through Freesurfers tcl scripts became too difficult to control, and since macOS catalina no longer supperts 32-bit programs (tcl) is not usable several users (me among them). So we have opted for a workflow that will first help you make a ggseg3d-atlas, then use that atlas to make the ggseg-atlas. This has worked well for our attempts so far, no holes or weird segmentation issues. We'd love you to have a look and see if that at all is a workflow that works for you. https://lcbc-uio.github.io/ggsegExtra/articles/customatlas.html |
Awesome! We ended up editing the holes out in Photoshop, but it is totally possible I'll have to remake the figure, in which case I'll definitely use this. I'll try to give it a test run soon. Sorry for the late response. This pandemic is a lot! |
if you manage making an annotation file, I'd love the atlas as part of the ggseg-family of atlases. So if you do get it working, please let ut know and we'll help you contribute an atlas :) |
@Athanasiamo And I have to remake the figure! Unfortunately, I had since updated my version of R to 3.6.2, for which ggsegExtra does not seem to be available. Would it be possible to make a version of ggsegExtra available for this version of R? Thank you! |
Hi @butellyn ! It should absolutely be available, but I suspect you have tried installing it from cran, where it is not available. You need to do |
Ah! Whoops! Thank you! |
The atlas creation fails on step 3. Here is the call that I am using: |
Got a little bit further. I think I should be using |
I'm surprised you got a lot further. The LCBC surface would have been created for you (without extra effort) if you had chosen to use 'fsaverage5' as a subject, which is what we recommend. 'fsaverage' is alot of vertices and will create a plot that is very slow to render in the end because it is so large. |
Ah, I had to switch to 'fsaverage' because that is the surface I made my annot files in the last time I took a crack at all of this. Maybe it is time to go back and recreate those. |
When I switch to the inflated surface ( |
Ah sorry, I see now there is some lack of information in the tutorial to make atlases. Thanks for pointing that out. Because the data usually need some post-processing (removing uneeded structures, renaming of things etc), the final output from the Before using the next function, try doing |
Thanks! I tried out the |
there are some gremlins here. I hope to get time to look further into this next week. |
Hey, just checking in on this. Our paper came out, but now everyone wants to keep using the atlas I made, so it would be nice to figure out how to permanently fix the holes. |
Hi @butellyn ! We just released the package with new pipelines and functions for creating atlases. If you managed to create an annotation file before, you should easily be able to use a process similar to what we describe here: |
Great that the new functions are working fairly well!
|
I think there are vertices that aren't mapping to the surface. These are the same annot files that got turned into the plot I created on January 30 above. One of the major issues I was running into was trying to figure out how to fill the holes. It seems like I tried viewing the surface in Freeview, but I got the following error: "Did not find any volume info After running |
I completely lot track of this issue, I'm terribly sorry. How far did you get in the end? |
Haha, no problem. I am actually no longer working on the project, because I transitioned from a data analyst role to being a PhD student at Northwestern. One of my replacements, Noah Hillman (@Nchillman, https://github.com/Nchillman), is working on this now. |
I have created a branch with my work on getting the Miccai/Oasis label set into ggseg:
https://github.com/butellyn/ggsegExtra/tree/master/data-raw/MiccaiOasis
MICCAI 2012 Labeling Challenge: http://www.neuromorphometrics.com/2012_MICCAI_Challenge_Data.html
The nifti of these labels was made by using joint label fusion to warp the labels from the OASIS brains to MNI 152 space.
I have made a lot of progress on getting these labels into ggseg, but I have run into a few issues along the way that may turn out to be big problems. I have never used freesurfer or connectome workbench before, so it's been quite a learning curve. I'm sorry for the issues that probably stem from my misunderstanding of freesurfer and connectome workbench. I have tried to answer my questions through exploring various listservs and stackoverflow.
I know you are working on an R function to get atlases into ggseg, which is awesome. If you don't have time to answer my questions below, or try running my code, could you try putting this atlas in using your new function? I am trying to make a figure for a paper that got an R&R. The fact that I can use ggplot to organize the figure is great for me, and for the person for whom I am making the figures. (I am trying to put together a very complicated figure that I need to be able to edit frequently and quickly.)
The main thing I am stuck on is mkMic.R (analogous to mkHo.R). One of the dependencies for one of the libraries loaded in mkHo.R is V8. Unfortunately, it failed to install and returned the following error message:
trying URL 'https://cran.mtu.edu/src/contrib/V8_3.0.1.tar.gz' Error in download.file(url, destfile, method, mode = "wb", ...) : cannot open URL 'https://cran.mtu.edu/src/contrib/V8_3.0.1.tar.gz' In addition: Warning message: In download.file(url, destfile, method, mode = "wb", ...) : cannot open URL 'https://cran.mtu.edu/src/contrib/V8_3.0.1.tar.gz': HTTP status was '404 Not Found' Warning in download.packages(pkgs, destdir = tmpd, available = available, : download of package ‘V8’ failed
In addition to this error,
mri_vol2surf
does not seem to exist in any of the libraries loaded in mkHo.R. I installed and loaded the freesurfer package for R, but this does not have mri_vol2surf either (but it does have mri_surf2surf). It doesn't look like you use test.*r.mgh later in the script, though, so I am not sure what the purpose of this line is. It also seems as if it is doing the exactly same thing as line 16 in miccaiOasisGGSEG.sh.Below I detail the problems I ran into while adapting your scripts for the Harvard-Oxford cortical atlas to the Miccai/Oasis label set. I have annotated my scripts some, but I think the full thought process may be useful for debugging, or for other users who are interested in getting an atlas into ggseg. (Note that I do not use relative paths throughout the script, aside from in R. OUTDIR, INDIR and SCRDIR were originally paths on my computer, but I changed them to
pwd
for portability. They should probably become command-line arguments.)The first major issue I ran into had to do with indexing. Freesurfer seems to expect the background to be coded as 0, and all other indices to be consecutive integers. My atlas was not coded this way. To get it closer, I subtracted 99 from all cortical ROI indices because the indices were 100-207. Unfortunately, a few of the indices were intentionally skipped because labels that were originally planned to be part of the atlas were not included in the final version. This made the whole process of re-indexing to consecutive integers a daunting/error-prone task. When I loaded these labels into freeview, I originally created the *h.mic.annot files using the following commands:
sudo mris_label2annot --sd ${SUBJECTS_DIR} --s fsaverage --ctab ${OUTDIR}/miccaiCtab.txt ${LABS_L} --h lh --a mic sudo mris_label2annot --sd ${SUBJECTS_DIR} --s fsaverage --ctab ${OUTDIR}/miccaiCtab.txt ${LABS_R} --h rh --a mic
miccaiCtab.txt
contains indices for both left and right hemispheres, and the indices match the indices in${INDIR}/mniMICCAI_LabelsCortical0.nii.gz
. Unfortunately, freesurfer clearly was not reading the indices from the idx column (which I created to match freesurfer's color lookup table; I tried a color look up table like the one created for Harvard-Oxford, but that failed with some error that I do not remember). I know this because it only read the number of lines in miccaiCtab.txt that corresponded to the number of ROIs in a given hemisphere. Then I split miccaiCtab.txt into miccaiCtab_R.txt and miccaiCtab_L.txt for left and right. Errors persisted (I couldn't open the labels in freeview), and I guessed that it may have to do with the fact that the indices were no longer (largely) consecutive integers. So I changed the indices in miccaiCtab_R.txt and miccaiCtab_L.txt, and it mostly worked. I could now see my labels in freeview. But the labels did not line up with the correct regions. At this point, I decided that this probably should not matter, since I could redefine index-label pairings in the final tibble for ggseg. I hope I was correct about this!Then I ran into an issue at line 66 in miccaiOasisGGSEG.sh. The outputs of mris_convert did not match the inputs to smooth_labels.sh in the instructions, so I had to change this. Hopefully I interpreted the intention here correctly. In smooth_labels.sh, I had to change to the key flag for -gifti-label-to-roi. I also couldn't get gnuparallel working on my computer, so I replaced those lines with code that produced what I think is the same output. Of concern, when I finally got to mkPics.sh, I noticed that my ROIs were still very choppy, so I think smooth_labels.sh probably did not work. I didn't run into any errors with my final version of smooth_labels.sh, but some parameter probably needs to be adjusted to make the labels even more smooth.
Other little problems showed up throughout, but these are the major ones. Please let me know if I can be of help with any documentation, or if you would like me to clarify anything about what I have done.
The text was updated successfully, but these errors were encountered: