Compared with cross-sectional studies, a longitudinal design can significantly reduce the confounding effect of inter-individual morphological variability by using each subject as his or her own control. As a result, longitudinal imaging studies are getting increased interest and popularity in various aspects of neuroscience.
The standard FreeSurfer pipeline is designed for the processing of individual data set, and thus not optimal for the processing of longitudinal data series. How to take into account the subject-wise and temporal correlation in a longitudinal data series and get more robust and reliable cortical and subcortical morphological measurements is an active research area in NMR center.
Although further improvements are constantly being sought, as the result of an early attempt, a longitudinal processing pipeline has been designed for the processing of longitudinal data and has shown proved success. The basic idea of this longitudinal scheme is to borrow the processing results of an early time point to help the processing of a later time point. As easily noticed, the FreeSurfer cortical and subcortical segmentation and parcellation procedure involves solving many complex nonlinear optimization problems, such as the deformable surface reconstruction, the nonlinear atlas-image registration, and the nonlinear spherical registration. These nonlinear optimization problems are usually solved using iterative methods, and the final results are known to be highly sensitive to the selection of a particular starting point (a.k.a. the initialization). It's our belief that by initializing the processing of a new data set in a longitudinal series using the processed results of an early time point, we can reduce the random variation in the processing procedure and improve the robustness and sensitivity of the overall longitudinal analysis. Such an initialization scheme makes sense also because a longitudinal design is often targeted at detecting small or subtle changes.
The longitudinal processing scheme is coded in the script called "recon-all-long", as compared to the standard FreeSurfer pipeline as described in the "recon-all" script. In the following, we list the major differences between the two scripts or the two processing streams. The two scripts will ultimatedly be combined as a single one. In the following, we assume that the longitudinal series have two time-points, tp1 and tp2, and tp1 has already been processed using the standard FreeSurfer recon-all. To process tp2 in the longitudinal way, "recon-all-long" can be used and the command reads like "recon-all-long -long -tp1 tp1 -subjid tp2 ...". "..." represents standard options as used when processing tp1.
Difference 1: The longitudinal scheme requires aligning the image data of tp2 to tp1. Due to the intra-subject correlation of the two data sets, a linear registration with a dof equal 6 or 9 is enough to get a good alignment between them. The alignment/registration is performed using the FSL FLIRT program, and the registration result (a coordinate transformation matrix) will be used to transfer information from tp1 to tp2 in later steps. As can be seen in the recon-all-long script, the alignment is computed as follows:
- "fsl_rigid_register -cost corratio -i $tp1dir/mri/orig.mgz -r $subjdir/mri/orig.mgz -o $subjdir/mri/orig_${tp1id}_to_${subjid}.mgz -dof 6 -ltamat $tp1dir/mri/transforms/$regfile"
"$regfile" stores the registration as a LTA file. The filename is automatically set inside the script, unless the user changes it using the "-reg" option.
Difference 2: Talairach Registration. In the original scheme, the Talairach registration is computed using MINC tools. In the longitudinal scheme, the Talairach registration for tp2 is computed by composing the linear registration from tp1 to tp2 and the Talairach registration for tp1. In particular, the following command is used:
- "mri_concatenate_lta -invert1 -tal $tp1dir/mri/orig.mgz $talairach_template_file $tp1dir/mri/transforms/$regfile $tp1dir/mri/transforms/talairach.xfm $subjdir/mri/transforms/talairach.xfm".
"mri_concatenate_lta" is a program to combine two consecutive linear transformation/registration into a single total transformation. "-invert1" indicates that the first transformation matrix need be inverted before composing with the second one. "-tal src_file trg_file" gives the source and target volume names for the first Talairach registration. "$talairach_template_file" is set to "${MINC_BIN_DIR}/../share/mni_autoreg/average_305.mnc" by default.
Difference 3: Intensity Normalization. If "-usetp1ctrlvol" is set, the longitudinal scheme will first map the automatically computed control points for tp1 (computed inside mri_normalize) to the volumetric space of tp2, and then use them to perform intensity normalization for tp2. By default, the control points for tp1 are not saved in the original script. Thus, recon-all-long will first regenerate the control points using
- "mri_normalize -mask $tp1dir/mri/brain.mgz -W $tp1dir/mri/ctrl_vol.mgz $tp1dir/mri/bias_vol.mgz $tp1dir/mri/nu.mgz $tp1dir/mri/T1_tmp.mgz".
Then the intensity normalization using the given control points (saved as a volume file "ctrl_vol.mgz"):
- "mri_normalize_tp2 -T1 $tp1dir/mri/nu.mgz -ctrl $tp1dir/mri/ctrl_vol.mgz -mask1 $tp1dir/mri/brain.mgz -xform $tp1dir/mri/transforms/$regfile $subjdir/mri/nu.mgz $subjdir/mri/T1.mgz"
We haven't investigated the mapping of manually picked control points from tp1 to tp2. If manual control points are necessary, it's better that the user pick them manually for the tp2 volume too.
Difference 4: GCA Registration. Similar to the Talairach registration, in the longitudinal scheme, the linear subcortical atlas registration for tp2 is computed by composing the linear atlas registration for tp1 and the linear mapping from tp1 to tp2:
- "mri_concatenate_lta -invert1 $tp1dir/mri/transforms/$regfile $tp1dir/mri/transforms/talairach.lta transforms/talairach.lta"
"-invert1" again indicates that the first LTA need be inverted before composing with the second. The rationale is easily understandable by drawing the source and target space for each LTA.
Difference 5: Canonical Registration (nonlinear). In the standard recon-all, this nonlinear atlas registration is initialized by the previous linear registration result:
- "mri_ca_register $UseCAAlign -mask brainmask.mgz -T transforms/talairach.lta $xopts norm.mgz $FREESURFER_HOME/average/$GCA transforms/talairach.m3z".
In the longitudinal scheme, the nonlinear registration for tp2 is initialized by the nonlinear registration result of tp1, and only local refinements are further performed to get the final registration:
- "mri_ca_register $UseCAAlign -mask brainmask.mgz -levels 2 -A 1 -l $tp1dir/mri/transforms/talairach.m3z $tp1dir/mri/transforms/$regfile -T transforms/talairach.lta norm.mgz $FREESURFER_HOME/average/$GCA transforms/talairach.m3z".
The options "-levels 2 -A 1" tell the program to do only local refinement. "-l $tp1dir/mri/transforms/talairach.m3z $tp1dir/mri/transforms/$regfile" is the longitudinal option that specifies the initial nonlinear registration and the mapping from tp1 to tp2. "-T transforms/talairach.lta" gives the linear registration as in the original scheme. This linear registration will still be used when cross-sequence atlas renormalization is needed (as specified by the $UseCAAlign option).
Difference 6: Subcortical Segmentation. In the longitudinal processing scheme, the final subcortical segmentation step again uses the segmentation result from tp1 to initialize the iterative labeling process:
- "mri_ca_label $UseCAAlign $xopts -l $tp1dir/mri/aseg.mgz $tp1dir/mri/transforms/$regfile norm.mgz transforms/talairach.m3z $FREESURFER_HOME/average/$GCA aseg.auto.mgz".
Difference 7: WM surface tessellation and topology correction. The whole process of generating the orig surface that involves WM tessellation, topology correction, and etc is not needed in the longitudinal processing of tp2, since the final gray/white surface from tp1 will be used as the initial gray/white surface for tp2. Consequently, the whole process is replaced by the following two commands just before running mris_make_surfaces:
- "mris_transform --dst $subjdir/mri/orig.mgz $tp1dir/surf/${hemi}.white $tp1dir/mri/transforms/$regfile $subjdir/surf/${hemi}.orig",
and
- "mris_transform --dst $subjdir/mri/orig.mgz $tp1dir/surf/${hemi}.white $tp1dir/mri/transforms/$regfile $subjdir/surf/${hemi}.orig_white".
That is, the final white surface from tp1 is mapped to the tp2 volume and is used as the orig surface for tp2 and also the "orig_white", i.e., the "initial white surface", for the later surface deformation. Similarly, the final pial surface from tp1 is mapped to tp2 and will be used as the initial pial surface for tp2:
- "mris_transform --dst $subjdir/mri/orig.mgz $tp1dir/surf/${hemi}.pial $tp1dir/mri/transforms/$regfile $subjdir/surf/${hemi}.orig_pial".
Difference 8: Make Final Surfaces. In the standard FreeSurfer, the orig surface is deformed to get the white surface, and the white surface is further deformed to get the pial surface. In the longitudinal scheme, the white and pial surfaces are both initialized using tp1's surface deformation results as described above, and the command line becomes:
- "mris_make_surfaces -orig_white orig_white -orig_pial orig_pial -orig orig_white -long -max 3.5 -mgz -T1 brain.finalsurfs $xopts $subjid $hemi".
The options "orig_white" and "orig_pial" specifies the initialization for the white and pial surface respectively. "-long" indicates the longitudinal scheme. Note that in the original scheme, the white and pial surfaces are guaranteed not to cross each other. This non-cross-intersection won't be guaranteed in the new scheme since the initial pial surface is independent of the final white surface. If non-cross-intersection is important, the user can remove the "-orig_pial" option and its argument, such that the pial surface is still initialized by the final white surface. But using both "-orig_white" and "-orig_pial" gives better thickness reproducibility.
Difference 9: Spherical Mapping. In the longitudinal scheme, the spherical map ($hemi.sphere) for tp2 is simply a copy from tp1. It's not hard to see why this is reasonable.
Difference 10: Spherical Registration. Like in subcortical segmentation, the nonlinear spherical registration for tp2 in the longitudinal scheme is initialized with the sphere.reg from tp1:
- "mris_register -curv -nosulc -norot $tp1dir/surf/$hemi.sphere.reg $AvgTif ../surf/$hemi.sphere.reg". 
"-nosulc" and "-norot" tell the program to ignore the initial linear alignment step in standard spherical registration.
(NOTE: the same principle may be applied for the contra-surface registration for tp2, but it's not currently implemented)
Difference 11: Cortical Parcellation. Similar to the subcortical labeling step, the cortical parcellation for tp2 in the longitudinal scheme is again initialized with the parcellation result from tp1:
- "mris_ca_label $xopts -long -R $tp1dir/label/${hemi}.aparc.annot $subjid $hemi ../surf/$hemi.sphere.reg $CPAtlas $annot"
This is done also for the second parcellation using another surface labeling scheme:
- "mris_ca_label $xopts -long -R $tp1dir/label/${hemi}.aparc.a2005s.annot $subjid $hemi ../surf/$hemi.sphere.reg $CPAtlas $annot"
The above is a complete list of all the differences between the standard recon-all and the longitudinal "recon-all-long" processing stream. The new options added to "recon-all-long" include "-long", "-tp1", "-usetp1ctrlvol", "-no-orig-pial", and "-regfile". Their meanings should be clear from the above description. Note that the "recon-all-long" script is modified from a dev version of "recon-all", and may not be consistent with the most recent version of "recon-all".
