-
Notifications
You must be signed in to change notification settings - Fork 18
Contributing: polygon atlases old
Welcome to the ggbrain wiki!
In this wiki, we will focus on describing how to provide the package with more atlases.
With this wiki, you can create your own atlas to work with ggbrain package or send us atlas you'd like to incorporate in the package. We will add more atlas images to ggbrain in the near future but we appreciate any suggestions or contributions you may have.
Creating new data.frames with atlas information, is a slightly labourious task, as it involved several steps.
This will need to as "flat" an image as possible. i.e. have no shading effects or the like. You should also know the actual number of colours the image contains for the next step.
for instance:
Notice how the colours are flat, without any shading.
Notice also how all the brains are roughly the same size, and aligned.
This set-up is the ideal starting point for any cortical atlas.
Subcortical atlases can have very different set-ups (see aseg
and midsagittal
for example)
This step requires the use of a program that can detect the contours of the colours in the raster image, and convert each into a vector. We have tried using online converters, Inkscape and several packages in R to do this, but by far Adobe Illustrator is the most effective in doing this. We recommend this video tutorial on how to do this in illustrator, if you have the program available.
As noted, we have tried several other options, Inkscape does a fair job with its trace bitmap
function, but requires much more manual labour after conversion. Illustrator requires minimal to none.
If you know of any other solution that may work, please let us know, so we can test it out.
Working with vector graphics in R is possible, but we found it to be a little tedious. This is why we opted for converting the vector graphic into shape-files that use geograpical coordinates.
This step requires:
i) conversion of vector images to AutoCAD DXF (Drawing Interchange Format, or Drawing Exchange Format).
One has plenty of options here. You can export svg images to AutoCAD DXF from Illustrator or even use any online converter.
ii) conversion of *DXF files into shape-files. Here we used QGIS a GIS Free and Open Source Software.
The GIS data may be loaded into R using OGR reading packages, and then fortified into a data.frame using ggplot2 (alternatively you can use the broom package). This will create a data.frame ready for plotting! Something like:
library(rgdal)
library(ggplot)
#Open shape-file object
geobrain <- readOGR(dsn = ".", layer = "dka")
# fortify (transform to data.frame)
geobrain <- fortify(geobrain, region="GEO_ID")
Each polygon (id) in the data.frame represents on of the vectors from the svg. Each of these need information on their hemispheres, side (lateral,medial etc), in addition to the name of either the topographical area or the network they belong to. This step often requires some manual editing depending on the quality of the vectorization.
As a minimum, the data.frame must contain the columns:
lat = x-axis coordinates
long = y-axis coordinates
area = name of network or topographical region
hemi = hemisphere the polygon is in
side = which side the of the brain the polygon is viewed from (lateral, medial, axial or sagittal)
label = the label used in the software the atlas is taken from (Freesurfer for instance has internal labels for its atlases like lh_transverse
for left transverse in the DKT atlas.)
Additionally, make sure that the minimum long and lat values are a close to 0 as possible.
This is necessary to get the stacked
position to work.
yourAtlas$long = yourAtlas$long - min(yourAtlas$long)
yourAtlas$lat = yourAtlas$lat - min(yourAtlas$lat)
As a cherry on the cake, you can send us a label to HEX color relation so we can add an option to plot the atlas with the palette you are used to.
The ggbrain
function can take any data.frame that is in the correct format.
If you have successfully created a data.frame with the above columns, you can test it in the function directly, to see if it plots as expected.
ggbrain(atlas=yourAtlas)
ggbrain(atlas=yourAtlas, position="stacked")
ggbrain(atlas=yourAtlas, position="stacked", mapping=aes(fill=area)
You are very welcome to contact the creators of this package for assistance on any step, or advice if a certain atlas is suitable. Generally, we believe that the atlases should not have too many parcellations, as increased number of colours is increasingly difficult to turn into vectors.