In this section, we outline the procedure for installing the MIT Photonic-Bands package. Mainly, this consists of downloading and installing various prerequisites. As much as possible, we have attempted to take advantage of existing packages such as BLAS, LAPACK, FFTW, and GNU Guile, in order to make our code smaller, more robust, faster, and more flexible. Unfortunately, this may make the installation of MPB more complicated if you do not already have these packages.
You will also need an ANSI C compiler, of course (gcc is fine), and installation will be easiest on a UNIX-like system (Linux is fine). In the following list, some of the packages are dependent upon packages listed earlier, so you should install them in more-or-less the order given.
Note: Many of these libraries may be available in
precompiled binary form, especially for GNU/Linux systems.  Be aware,
however, that library binary packages often come in two parts,
library and library-dev, and both
are required to compile programs using it.
Note: It is important that you use the same Fortran
compiler to compile Fortran libraries (like LAPACK) and for
configuring MPB.  Different Fortran compilers often have incompatible
linking schemes.  (The Fortran compiler for MPB can be set via the
F77 environment variable.)
First, let's review some important information about installing software on Unix systems, especially in regards to installing software in non-standard locations. (None of these issues are specific to MPB, but they've caused a lot of confusion among our beloved users.)
Most of the software below, including MPB, installs under
/usr/local by default; that is, libraries go in
/usr/local/lib, programs in /usr/local/bin,
etc.  If you don't have root privileges on your machine,
you may need to install somewhere else, e.g. under
$HOME/install (the install/ subdirectory of
your home directory).  Most of the programs below use a GNU-style
configure script, which means that all you would do to
install there would be:
./configure --prefix=$HOME/installwhen configuring the program; the directories
$HOME/install/lib etc. are created automatically as
needed.
There are two further complications.  First, if you install in a
non-standard location (and /usr/local is considered
non-standard by some proprietary compilers), you will need to tell the
compilers where to find the libraries and header files that you
dutifully installed.  You do this by setting two environment variables:
setenv LDFLAGS "-L/usr/local/lib" setenv CPPFLAGS "-I/usr/local/include"Of course, substitute whatever installation directory you used. Do this before you run the
configure scripts,
etcetera.  You may need to include multiple -L and
-I flags (separated by spaces) if your machine has stuff
installed in several non-standard locations.  Bourne shell users
(e.g. bash or ksh) should use the
"export FOO=bar" syntax instead of csh's
"setenv FOO bar", of course.
You might also need to update your PATH so that you
can run the executables you installed (although
/usr/local/bin is in the default PATH on
many systems).  e.g. if we installed in our home directory as
described above, we would do:
setenv PATH "$HOME/install/bin:$PATH"
Second, many of the packages installed below (e.g. Guile) are
installed as shared libraries.  You need to make sure that your
runtime linker knows where to find these shared libraries.  The bad
news is that every operating system does this in a slightly different
way.  The good news is that, when you run make install
for the packages involving shared libraries, the output includes the
necessary instructions specific to your system, so pay close
attention!  It will say something like "add LIBDIR to the
," where
foobar environment variableLIBDIR will be your library installation directory
(e.g. /usr/local/lib) and foobar is some
environment variable specific to your system
(e.g. LD_LIBRARY_PATH on some systems, including Linux).
For example, you might do:
setenv foobar "/usr/local/lib:$foobar"Note that we just add to the library path variable, and don't replace it in case it contains stuff already. If you use Linux and have
root privileges, you can instead simply run
/sbin/ldconfig, first making sure that
a line "/usr/local/lib" (or whatever) is in
/etc/ld.so.conf.
If you don't want to type these commands every time you log in, you
can put them in your ~/.cshrc file (or
~/.profile, or ~/.bash_profile, depending on
your shell).  
MPB, and many of the libraries it calls, are written in C, but it
also calls libraries such as BLAS and LAPACK (see below) that are
usually compiled from Fortran.  This can cause some added difficulty
because of the various linking schemes used by Fortran compilers.
MPB's configure script attempts to detect the Fortran
linking scheme automatically, but in order for this to work you
must use the same Fortran compiler and options with MPB as were used
to compile BLAS/LAPACK.
By default, MPB looks for a vendor Fortran compiler first
(f77, xlf, etcetera) and then looks for GNU
g77.  In order to manually specify a Fortran compiler
foobar you would configure MPB with
'./configure F77=foobar ...'.
If, when you compiled BLAS/LAPACK, you used compiler options that
alter the linking scheme (e.g. g77's
-fcase-upper or -fno-underscoring), you will
need to pass the same flags to MPB via './configure
FFLAGS="...flags..." ...'.
One final note: you may run into trouble if you use a C compiler by
a different vendor than your Fortran compiler, due to incompatible
libraries.  By default, MPB looks for a vendor C compiler
(cc) first, but you can specify a different C compiler
with './configure CC=foobar ...'.
The first thing you must have on your system is a BLAS implementation. "BLAS" stands for "Basic Linear Algebra Subroutines," and is a standard interface for operations like matrix multiplication. It is designed as a building-block for other linear-algebra applications, and is used both directly by our code and in LAPACK (see below). By using it, we can take advantage of many highly-optimized implementations of these operations that have been written to the BLAS interface. (Note that you will need implementations of BLAS levels 1-3.)
You can find more BLAS information, as well as a basic implementation, on the BLAS Homepage. Once you get things working with the basic BLAS implementation, it might be a good idea to try and find a more optimized BLAS code for your hardware. Vendor-optimized BLAS implementations are available as part of the Compaq CXML, IBM ESSL, SGI sgimath, and other libraries. Recently, there has also been work on self-optimizing BLAS implementations that can achieve performance competitive with vendor-tuned codes; see the ATLAS homepage (and also PhiPACK). Links to more BLAS implementations can be found on SAL. I recommend ATLAS, but it does take some time to compile.
Note that the generic BLAS does not come with a
Makefile; compile it with something like:
mkdir blas && cd blas # the BLAS archive does not create its own directory get http://www.netlib.org/blas/blas.tgz gunzip blas.tgz tar xf blas.tar f77 -c -O3 *.f # compile all of the .f files to produce .o files ar rv libblas.a *.o # combine the .o files into a library su -c "cp libblas.a /usr/local/lib" # switch to root and install
(Replace -O3 with your favorite optimization options.
On Linux, I use g77 -O3 -fomit-frame-pointer
-funroll-loops, with -malign-double -mcpu=i686 on
a Pentium II.)  Note that MPB looks for the standard BLAS library with
-lblas, so the library file should be called
libblas.a and reside in a standard directory like
/usr/local/lib.  (See also below for the
--with-blas=lib option to MPB's
configure script, to manually specify a library location.)
LAPACK, the Linear Algebra PACKage, is a standard collection of routines, built on BLAS, for more-complicated (dense) linear algebra operations like matrix inversion and diagonalization. You can download LAPACK from the LAPACK Home Page. More LAPACK links can be found on SAL.
Note that MPB looks for LAPACK by linking with
-llapack.  This means that the library must be called
liblapack.a and be installed in a standard directory like
/usr/local/lib (alternatively, you can specify another
directory via the LDFLAGS environment variable as
described earlier).  (See also below for the
--with-lapack=lib option to MPB's
configure script, to manually specify a library location.)
Optionally, MPB is able to run on a distributed-memory parallel machine, and to do this we use the standard MPI message-passing interface. You can learn about MPI from the MPI Home Page. Most commercial supercomputers already have an MPI implementation installed; two free MPI implementations that you can install yourself are MPICH and LAM. MPI is not required to compile the ordinary, uniprocessor version of MPB.
In order for the MPI version of MPB to run successfully, we have a slightly nonstandard requirement: each process must be able to read from the disk. (This way, Guile can boot for each process and they can all read your control file in parallel.) Many (most?) commercial supercomputers, Linux Beowulf clusters, etcetera, satisfy this requirement.
Also, in order to get good performance, you'll need fast interconnect hardware such as Myrinet; 100Mbps Ethernet probably won't cut it. The speed bottleneck comes from the FFT, which requires most of the communications in MPB. FFTW's MPI transforms (see below) come with benchmark programs that will give you a good idea of whether you can get speedups on your system. Of course, even with slow communications, you can still benefit from the memory savings per CPU for large problems.
As described below, when you configure MPB with
MPI support (--with-mpi), it installs itself as
mpb-mpi.  See also the user reference section for
information on using MPB on parallel machines.
MPI support in MPB is thanks to generous support from Clarendon Photonics.
We require a portable, standard binary format for outputting the electromagnetic fields and similar volumetric data, and for this we use HDF. (If you don't have HDF5, you can still compile MPB, but you won't be able to output the fields or the dielectric function.)
HDF is a widely-used, free, portable library and file format for multi-dimensional scientific data, developed in the National Center for Supercomputing Applications (NCSA) at the University of Illinois (UIUC, home of the Fighting Illini and alma mater to many of this author's fine relatives).
There are two incompatible versions of HDF, HDF4 and HDF5 (no, not
HDF1 and HDF2).  We require the newer version, HDF5.  Many
visualization and data-analysis tools still use HDF4, but HDF5
includes an h5toh4 conversion program that you can use if
you need HDF4 files.
HDF5 includes parallel I/O support under MPI, which can be enabled
by configuring it with --enable-parallel.  (You may also
have to set the CC environment variable to
mpicc. The resulting HDF5 library, however, may not work
with the serial MPB.)  This is not required to use the
parallel version of MPB.  MPB includes optional code to support this
feature, and it may result in faster file I/O in the parallel MPB, but
it is currently untested.  (Let me know if you try it out; the worst
that can happen is that MPB crashes or outputs garbage fields.)
You can get HDF and learn about it on the HDF Home Page. We have also collected some links to useful HDF software.
FFTW is a self-optimizing, portable, high-performance FFT implementation, including both serial and parallel FFTs. You can download FFTW and find out more about it from the FFTW Home Page.
If you want to use MPB on a parallel machine with MPI, you will
also need to install the MPI FFTW libraries (this just means including
--enable-mpi in the FFTW configure flags).
GNU Readline is a library to provide command-line history, tab-completion, emacs keybindings, and other shell-like niceties to command-line programs. This is an optional package, but one that can be used by Guile (see below) if it is installed; we recommend getting it. You can download Readline from the GNU ftp site. (Readline is typically preinstalled on GNU/Linux systems).
GNU Guile is an extension/scripting language implementation based on Scheme, and we use it to provide a rich, fully-programmable user interface with minimal effort. It's free, of course, and you can download it from the Guile Home Page. (Guile is typically included with GNU/Linux systems.)
Important: If you are using an RPM-based Linux system with
Guile pre-installed, please note that you must also install the
guile-devel RPM (which should be on your CD, but is not
installed by default).
If you want to be a developer of the MPB package (as opposed to
merely a user), you will also need the GNU Autoconf program.  Autoconf
is a portability tool that generates configure scripts to
automatically detect the capabilities of a system and configure a
package accordingly.  You can find out more at the Autoconf Home Page
(autoconf is typically installed by default on Linux systems).  In
order to install Autoconf, you will also need the GNU m4
program if you do not already have it (see the GNU m4 Home Page).
Instead of using Guile directly, we separated much of the user
interface code into a package called libctl, in the hope that this
might be more generally useful.  libctl automatically handles the
communication between the program and Guile, converting complicated
data structures and so on, to make it even easier to use Guile to
control scientific applications.  Download libctl from the libctl home site, unpack
it, and run the usual configure, make,
make install sequence.  You'll also want to browse its manual, as this will
give you a general overview of what the user interface will be like.
If you are not the system administrator of your machine, and/or
want to install libctl somewhere else (like your home directory), you
can do so with the standard --prefix=dir option to
configure (the default prefix is
/usr/local).  In this case, however, you'll need to
specify the location of the libctl shared files for the MPB package,
using the --with-libctl=dir/share/libctl option to
the MPB configure script.
Okay, if you've made it all the way here, you're ready to install the MPB package and start cranking out eigenmodes. (You can download the latest version and read this manual at the MIT Photonic-Bands Homepage.) Once you've unpacked it, just run:
./configure make
to configure and compile the package (see below to install).
Hopefully, the configure script will correctly detect the
BLAS, FFTW, etcetera libraries that you've dutifully installed, as
well as the C compiler and so on, and the make
compilation will proceed without a hitch.  If not, it's a Simple
Matter of Programming to correct the problem.
configure accepts several flags to help control its
behavior.  Some of these are standard, like
--prefix=dir to specify and installation directory
prefix, and some of them are specific to the MPB package
(./configure --help for more info).  The
configure flags specific to MPB are:
--with-inv-symmetry
mpbi instead of mpb, so that you can have
versions both with and without inversion symmetry installed at the
same time.  To install both mpb and
mpbi, you should do:
./configure make su -c "make install" make distclean ./configure --with-inv-symmetry make su -c "make install"
--with-hermitian-eps
--enable-single
float) instead of the default
double precision (C double) for computations.  (Not
recommended.)
--without-hdf5
--with-mpi
mpb-mpi.  Requires MPI and MPI FFTW libraries to be installed, as described
above.
Does not compile the serial MPB, or mpb-data;
if you want those, you should make distclean and
compile/install them separately.  
--with-mpi can be used along with
--with-inv-symmetry, in which case the program is
installed as mpbi-mpi (try typing that five times
quickly).
--with-libctl=dir
/usr nor /usr/local), you need to specify
the location of the libctl directory, dir.  This
is either prefix/share/libctl, where
prefix is the installation prefix of libctl, or the
original libctl source code directory.
- --with-blas=lib
- The configurescript automatically attempts to detect
accelerated BLAS libraries, like DXML (DEC/Alpha), SCSL and SGIMATH
(SGI/MIPS), ESSL (IBM/PowerPC), ATLAS, and PHiPACK.  You can, however,
force a specific library name to try via--with-blas=lib.
- --with-lapack=lib
- Cause the configurescript to look for a LAPACK
library calledlib(the default is to use-llapack).
- --disable-checks
- Disable runtime checks.  (Not recommended; the disabled checks
shouldn't take up a significant amount of time anyway.)
- --enable-prof
- Compile for performance profiling.
- --enable-debug
- Compile for debugging, adding extra runtime checks and so on.
- --enable-debug-malloc
- Use special memory-allocation routines for extra debugging (to
check for array overwrites, memory leaks, etcetera).
- --with-efence
- More debugging: use the Electric Fence library, if
available, for extra runtime array bounds-checking.
You can further control configure by setting various
environment variables, such as:
CC: the C compiler command
CFLAGS: the C compiler flags (defaults to -O3).
CPPFLAGS: -Idir flags to tell the
C compiler additional places to look for header files.
LDFLAGS: -Ldir flags to tell the
linker additional places to look for libraries.
LIBS: additional libraries to link against.
Once compiled, the main program (as opposed to various test
programs) resides in the mpb-ctl/ subdirectory, and is
called mpb.  You can install this program under
/usr/local (or elsewhere, if you used the
--prefix flag for configure), by running:
su -c "make install"
The "su" command is to switch to root for installation
into system directories.  You can just do make install if
you are installing into your home directory instead.
If you make a mistake (e.g. you forget to specify a needed
-Ldir flag) or in general want to start over from
a clean slate, you can restore MPB to a pristine state by running:
make distclean