Differences between revisions 30 and 35 (spanning 5 versions)
Revision 30 as of 2015-10-28 10:27:15
Size: 3273
Editor: ZekeKaufman
Comment:
Revision 35 as of 2015-11-03 18:52:49
Size: 2988
Editor: ZekeKaufman
Comment:
Deletions are marked like this. Additions are marked like this.
Line 37: Line 37:
=== 3rd Party Depandancies === === Library Dependencies ===
Line 39: Line 39:

Download and install the prepackaged bundle of open-source libraries required for building Freesurfer:
In order to compile freesurfer, you will need to download and install our prebuilt bundled of 3rd party dependancies. Download the package and remember the location as you will need to pass the directory containing the 3rd party libraries to the {{{configure}}} script.
Line 45: Line 44:
$> sudo mkdir -p /usr/pubsw/packages
$> sudo tar -C /usr/pubsw/packages -xzvf centos6-x86_64-packages.tar.gz
$> tar -xzvf centos6-x86_64-packages.tar.gz
$> cd centos6-x86_64-packages
$> ./setup.sh
Line 48: Line 48:

It is theoretically possible to install the bundle in any location on your system, but that would require manually passing the location for each library when running the {{{configure}}} script. By installing in {{{/usr/pubsw/packages}}} the {{{configure}}} script will automatically find them.

## Lastly, some system will complain about a missing jpeg library. If this happens, create the following symbolic link:
## {{{
## $> cd /usr/lib64
## $> sudo ln -s libjpeg.so.62 libjpeg.so
## }}}

/* '''''On 32bit systems'''''{{{wget ftp://surfer.nmr.mgh.harvard.edu/pub/dist/fs_supportlibs/prebuilt/centos6_x86_64/centos6-x86_64-packages.tar.gz mkdir -p /usr/pubsw/packages tar -C /usr/pubsw/packages -xzvf centos6-x86_64-packages.tar.gz }}} */
Line 63: Line 53:
$> ./configure --prefix=/home/USER/freesurfer $> ./configure --prefix=/home/username/fs_install --with=pkgs-dir=/home/username/centos6-x86_64-packages
Line 68: Line 58:

Its possible some systems (Ubuntu) will complain about a missing jpeg library after the {{{configure}}} script is run, or during runtime. If this happens, create the following symbolic link:
{{{
$> cd /usr/lib64
$> sudo ln -s libjpeg.so.62 libjpeg.so
}}}

This page is targeted at those who wish to develop and build the freesurfer source code on their Linux platform. These instructions have been tested for CentOS6 x86_64 desktop edition.

1. Get the Source Code

If you have access within the Martinos Center firewall, follow the steps below to download the source code from CVS. Non-Martinos users can get readonly CVS access to the source code by following the directions on this page:

# Local:
$> export CVSROOT=/space/repo/1/dev
$> cvs checkout -P dev

# Remote:
$> export CVSROOT=:ext:USERNAME@door.nmr.mgh.harvard.edu:/space/repo/1/dev
$> cvs checkout -P dev

2. Install System Libraries

The following system packages are required on CentOS6 systems before building. Equivalent or similar packages will be required on other linux distributions.

$> yum groupinstall "Development Tools"
$> yum install mesa-libGLU-devel \
            freetype-devel.x86_64 \
            libuuid-devel.x86_64 \
            uuid-c++-devel.x86_64 \
            libXmu-devel.x86_64 \
            libXi-devel.x86_64 \
            lapack-devel.x86_64 \
            liblapack-devel.x86_64 \
            libXaw-devel.x86_64 \
            libpng-devel.x86_64

3. Library Dependencies

In order to compile freesurfer, you will need to download and install our prebuilt bundled of 3rd party dependancies. Download the package and remember the location as you will need to pass the directory containing the 3rd party libraries to the configure script.

$> wget ftp://surfer.nmr.mgh.harvard.edu/pub/dist/fs_supportlibs/prebuilt/centos6_x86_64/centos6-x86_64-packages.tar.gz
$> tar -xzvf centos6-x86_64-packages.tar.gz
$> cd centos6-x86_64-packages
$> ./setup.sh

4. Setup, Configure, Make

Determine the location you want Freesurfer to be installed. For example, in case case we will assume the user wants freesurfer to be installed in /home/USER/freesurfer. Type the following commands in the top-level Freesurfer directory (the directory that contains configure.in and all the mri_* and mris_* directories.)

$> ./setup_configure
$> ./configure --prefix=/home/username/fs_install --with=pkgs-dir=/home/username/centos6-x86_64-packages
$> make -j4
$> make install

Done!

Its possible some systems (Ubuntu) will complain about a missing jpeg library after the configure script is run, or during runtime. If this happens, create the following symbolic link:

$> cd /usr/lib64
$> sudo ln -s libjpeg.so.62 libjpeg.so

Send your comments/questions/feedback to zkaufman@nmr.mgh.harvard.edu