1 |
|
---|
2 | /** \page compile Compiling
|
---|
3 |
|
---|
4 | <ul>
|
---|
5 | <li> \ref compilepre
|
---|
6 | <li> \ref compilepreopt
|
---|
7 | <li> \ref compileconf
|
---|
8 | <ul>
|
---|
9 | <li> \ref compilecca
|
---|
10 | </ul>
|
---|
11 | <li> \ref compilecomp
|
---|
12 | <li> \ref compilecheck
|
---|
13 | </ul>
|
---|
14 |
|
---|
15 | \section compilepre Prerequisites
|
---|
16 |
|
---|
17 | Make sure that you have the following programs available. Most can be found
|
---|
18 | at any GNU software FTP repository.
|
---|
19 |
|
---|
20 | <ul>
|
---|
21 |
|
---|
22 | <li> Compilers for the C, C++, and FORTRAN languages are needed. The
|
---|
23 | FORTRAN compiler is used to determine the linkage conventions for
|
---|
24 | the BLAS libraries, however, you can turn off the use of a FORTRAN
|
---|
25 | compiler by giving <tt>--without-f77</tt> as an option to the
|
---|
26 | configure script, however, this will not work unless you
|
---|
27 | only want the utility libraries. The compilers listed below are
|
---|
28 | known to work. Other ISO C++ compilers should work as well.
|
---|
29 |
|
---|
30 | <ul>
|
---|
31 |
|
---|
32 | <li> GCC 2.96 and later, available from <a
|
---|
33 | href="http://gcc.gnu.org">http://gcc.gnu.org</a>. However,
|
---|
34 | the 3.0 and 3.0.1 releases of GCC are not recommended.
|
---|
35 |
|
---|
36 | <li> IBM xlC 5.0.2 and later work with both 32 and 64 bit modes
|
---|
37 | Use the versions of the compilers with the "_r" appended to
|
---|
38 | the name, since SC uses multi-threading. You must also
|
---|
39 | specify that RTTI is used: <tt>--with-cxx='xlC_r
|
---|
40 | -qrtti'</tt>.
|
---|
41 |
|
---|
42 | <li> Compaq/Alpha/Linux with Compaq C++ 6.3.6.8 and later work.
|
---|
43 | Special configure options are needed: <tt>--with-cxx='cxx
|
---|
44 | -D__USE_STD_IOSTREAM'</tt>
|
---|
45 |
|
---|
46 | <li> The Intel 5.0.1 Linux compilers for IA-32 work. Version
|
---|
47 | 5.0.1 for IA-64 will not work.
|
---|
48 |
|
---|
49 | <li> The KAI version 4.0e1 compiler works. Special configure
|
---|
50 | options are needed: <tt>--with-cxx='KCC
|
---|
51 | --one_instantiation_per_object' --with-ar=KCC
|
---|
52 | --with-ar-flags=-o</tt>
|
---|
53 |
|
---|
54 | </ul>
|
---|
55 |
|
---|
56 | <li> The Basic Linear Algebra Subprograms (BLAS) are required. A
|
---|
57 | prepackaged version of BLAS is available for most machines.
|
---|
58 | Consult you operating system documentation for more information.
|
---|
59 | If precompiled BLAS routines are not available for your machine,
|
---|
60 | the source can be obtained from <a
|
---|
61 | href="http://www.netlib.org/blas">http://www.netlib.org/blas</a>.
|
---|
62 | The file blas.tgz contains the source for all of the BLAS
|
---|
63 | routines. If the BLAS library is not named libblas.a or is not
|
---|
64 | installed in the default library search path, then configure must
|
---|
65 | be given --with-libs, --with-libdirs, or both.
|
---|
66 |
|
---|
67 | <li> The Linear Algebra Package (LAPACK) 3.0 is required. A
|
---|
68 | prepackaged version of LAPACK is available for most machines.
|
---|
69 | Consult you operating system documentation for more information.
|
---|
70 | If a precompiled LAPACK is not available for your machine, the
|
---|
71 | source can be obtained from <a
|
---|
72 | href="http://www.netlib.org/lapack">http://www.netlib.org/lapack</a>.
|
---|
73 | The file lapack.tgz contains the source for all of the LAPACK
|
---|
74 | routines. If the LAPACK library is not named liblapack.a or is
|
---|
75 | not installed in the default library search path, then configure
|
---|
76 | must be given --with-libs, --with-libdirs, or both.
|
---|
77 |
|
---|
78 | <li> If you modify the scanner source file, then a
|
---|
79 | lexical analyzer generator is required to generate code to read
|
---|
80 | input files. The flex program is used for this purpose.
|
---|
81 | However, the most common version of flex, 2.5.4a, does
|
---|
82 | not generate legal C++. It may be necessary to download,
|
---|
83 | compile, and install a more recent version of flex from <a
|
---|
84 | href="http://lex.sourceforge.net">http://lex.sourceforge.net</a>.
|
---|
85 |
|
---|
86 | Make sure that <tt>FlexLexer.h</tt> from flex is in your include
|
---|
87 | path. You may need to give the path to <tt>FlexLexer.h</tt> to
|
---|
88 | configure with an argument that looks something like:
|
---|
89 | <tt>--with-include=-I/usr/local/include</tt>
|
---|
90 |
|
---|
91 | <li> If you modify a parser source file, then GNU bison (version 1.24
|
---|
92 | or greater) is needed. This is a parser generator used to
|
---|
93 | generate code to read input files.
|
---|
94 |
|
---|
95 | <li> GNU gmake (version 3.70 or greater): GNU specific extensions to make
|
---|
96 | are used extensively.
|
---|
97 |
|
---|
98 | <li> perl: This is used to convert template classes to macros, generate
|
---|
99 | and check the validation suite etc. To compile SC, either perl 4
|
---|
100 | or perl 5 will work. To generate the validation inputs and
|
---|
101 | automatically check the outputs, perl 5.003 or later is needed.
|
---|
102 |
|
---|
103 | </ul>
|
---|
104 |
|
---|
105 | \section compilepreopt Optional Packages
|
---|
106 |
|
---|
107 | The following packages are not necessary to compile MPQC, but may provide additional
|
---|
108 | features.
|
---|
109 |
|
---|
110 | <ul>
|
---|
111 |
|
---|
112 | <li> A Message Passing Interface (MPI) is required to use MPQC in
|
---|
113 | parallel on distributed memory machines.
|
---|
114 |
|
---|
115 | <li> The parallel MP2 and MP2-R12 methods require direct access to
|
---|
116 | remote memory. This requires one of two features: A thread-safe
|
---|
117 | MPI (<a href="http://www.mpi-softtech.com">MPI Software
|
---|
118 | Technology, Inc.</a> has developed a thread-safe MPI) or the <a
|
---|
119 | href="http://www.emsl.pnl.gov/docs/parsoft/armci/">Aggregate
|
---|
120 | Remote Memory Copy Interface (ARMCI)</a>. These respectively
|
---|
121 | permit remote memory access through the ARMCIMemoryGrp and the
|
---|
122 | MTMPIMemoryGrp classes, respectively.
|
---|
123 |
|
---|
124 | <li> Libint (version 1.1.0 or higher): This is a machine-generated
|
---|
125 | library that can be used for evaluation of certain molecular
|
---|
126 | integrals. IntegralCints and MBPT2_R12 classes depend on this
|
---|
127 | library. The library is freely available under GNU Public License
|
---|
128 | (GPL) from <a
|
---|
129 | href="http://www.ccmst.gatech.edu/evaleev/libint/">www.ccmst.gatech.edu/evaleev/libint/</a>.
|
---|
130 |
|
---|
131 | <li> Cca-chem-generic (version 0.2.0 or higher, and associated CCA tools):
|
---|
132 | This package allows both stand-alone and embedded component applications
|
---|
133 | to be formed using MPQC-based components. Visit the
|
---|
134 | <a href="http://cca-forum.org/~cca-chem">CCA Chemistry Component Toolkit Homepage</a>
|
---|
135 | for information on the freely available source code.
|
---|
136 |
|
---|
137 | </ul>
|
---|
138 |
|
---|
139 | \section compileconf Configuration
|
---|
140 |
|
---|
141 | You can build MPQC in the source code directory or you can make a
|
---|
142 | companion directory which will be used to hold all of the files generated
|
---|
143 | by the compilation. You may name this directory anything you want.
|
---|
144 | Typically, this directory is named to indicate the architecture
|
---|
145 | (e.g. <tt>mpqc.i686-linux</tt>) and will be referred to as the target
|
---|
146 | directory below.
|
---|
147 |
|
---|
148 | In the target directory execute the <tt>configure</tt> command which is
|
---|
149 | located in the SC source directory. Use the absolute pathname to the
|
---|
150 | configure script. This command should build a hierarchy of target
|
---|
151 | directories and the necessary makefiles. Do a <tt>configure --help</tt> to
|
---|
152 | see a list of options. Options are specified with an equals sign, as in
|
---|
153 | <tt>configure --prefix=/usr/local</tt>. Some options, such as all the
|
---|
154 | <tt>enable</tt> and <tt>disable</tt> options, do not require an argument.
|
---|
155 | Useful options to configure include:
|
---|
156 |
|
---|
157 | <dl>
|
---|
158 |
|
---|
159 | <dt><tt>--prefix</tt><dd>Specifies the installation directory. The default
|
---|
160 | is <tt>/usr/local/mpqc/</tt><i>version-number</i>
|
---|
161 |
|
---|
162 | <dt><tt>--enable-debug</tt><dd>Options for debugging will be given to the
|
---|
163 | compiler. Use <tt>--enable-debug=opt</tt> to use both debugging and
|
---|
164 | optimization options.
|
---|
165 |
|
---|
166 | <dt><tt>--with-default-parallel</tt><dd>Gives the default parallism
|
---|
167 | specializations. Can be <tt>none</tt> for no default or <tt>mtmpi</tt>
|
---|
168 | for MTMPIMemoryGrp (MPI must be fully thread-safe) and MPIMessageGrp
|
---|
169 | specializations. The parallelism model can be overridden with command
|
---|
170 | line arguments or environmental variables.
|
---|
171 |
|
---|
172 | <dt><tt>--enable-always-use-mpi</tt>This can be given if MPIMessageGrp
|
---|
173 | is to be the only MessageGrp that will be used. This option should
|
---|
174 | be given if the real argc and argv must be given to MPI_Init.
|
---|
175 |
|
---|
176 | <dt><tt>--disable-parallel</tt><dd>Do not try to find communications
|
---|
177 | libraries.
|
---|
178 |
|
---|
179 | <dt><tt>--disable-threads</tt><dd>Do not try to find the multi-thread
|
---|
180 | libraries.
|
---|
181 |
|
---|
182 | <dt><tt>--enable-shared</tt><dd>Use shared libraries. This will
|
---|
183 | reduce the size of executables, if shared libraries are supported
|
---|
184 | on your system.
|
---|
185 |
|
---|
186 | <dt><tt>--disable-static</tt><dd>Do not build libraries for static linking.
|
---|
187 |
|
---|
188 | <dt><tt>--enable-ref-debug</tt><dd>Check for overwrites and overflows of
|
---|
189 | reference counts. Implied by ``--enable-debug''.
|
---|
190 |
|
---|
191 | <dt><tt>--disable-ref-macros</tt><dd>Use template classes for reference
|
---|
192 | counting. The default is to use a CPP macro to generate a class
|
---|
193 | definition.
|
---|
194 |
|
---|
195 | <dt><tt>--enable-cross-compile</tt><dd>If this option is set then the
|
---|
196 | configure script will take care to not execute any compiled test
|
---|
197 | programs.
|
---|
198 |
|
---|
199 | <dt><tt>--enable-shared-libs</tt><dd>This will generate shared objects and
|
---|
200 | link with them instead of standard ``.a'' libraries. This works on a
|
---|
201 | Linux-ELF system.
|
---|
202 |
|
---|
203 | <dt><tt>--enable-components</tt><dd>This will generate CCA components and
|
---|
204 | enable embedded CCA frameworks within MPQC.
|
---|
205 |
|
---|
206 | <dt><tt>--with-build-id</tt><dd>This is used to generate unique shared
|
---|
207 | library names and a unique default prefix for an MPQC installation.
|
---|
208 | Unique shared library names must be used used by package distributors if
|
---|
209 | a non-official ABI is used. The official ABI is GCC-3.2. Earlier
|
---|
210 | versions of GCC are not compatible. Installations with multiple C++
|
---|
211 | compilers that use shared libraries should use --with-build-id to avoid
|
---|
212 | accidentally dynamically linking with the wrong libraries.
|
---|
213 |
|
---|
214 | <dt><tt>--with-default-memory</tt><dd>This specifies the default
|
---|
215 | memory allocation, which is used in absense of the memory> keyword in user's input.
|
---|
216 | The default is 32 million bytes (roughly, 32 MB).
|
---|
217 |
|
---|
218 | <dt><tt>--with-cc</tt><dd>Gives the name of the C compiler.
|
---|
219 |
|
---|
220 | <dt><tt>--with-cc-optflags</tt><dd>By default configure will attempt to
|
---|
221 | guess a reasonable set of optimization flags. These flags will be
|
---|
222 | overridden by the argument given to this keyword.
|
---|
223 |
|
---|
224 | <dt><tt>--with-cxx</tt><dd>Gives the name of the C++ compiler.
|
---|
225 |
|
---|
226 | <dt><tt>--with-cxx-optflags</tt><dd>By default configure will attempt to
|
---|
227 | guess a reasonable set of optimization flags. These flags will be
|
---|
228 | overridden by the argument given to this keyword.
|
---|
229 |
|
---|
230 | <dt><tt>--with-f77</tt><dd>Gives the name of the FORTRAN compiler.
|
---|
231 |
|
---|
232 | <dt><tt>--without-f77</tt><dd>configure will not try to find a FORTRAN
|
---|
233 | compiler. This can only be used if nothing more than the utility
|
---|
234 | libraries are needed.
|
---|
235 |
|
---|
236 | <dt><tt>--with-ranlib</tt><dd>Gives the name of the archive indexing
|
---|
237 | utility.
|
---|
238 |
|
---|
239 | <dt><tt>--with-ar</tt><dd>Gives the name of the program that makes
|
---|
240 | libraries.
|
---|
241 |
|
---|
242 | <dt><tt>--with-ld</tt><dd>Gives the name of the object linker.
|
---|
243 |
|
---|
244 | <dt><tt>--with-include</tt><dd>Gives directories in which include files
|
---|
245 | should be sought. For example, <tt>--with-include="-I/u/local/inc
|
---|
246 | -I/u/cljanss/include"</tt>
|
---|
247 |
|
---|
248 | <dt><tt>--with-libs</tt><dd>Specifies libraries that executables should be
|
---|
249 | linked with. For example, <tt>--with-libs=-llapack_IRIX.a</tt>.
|
---|
250 |
|
---|
251 | <dt><tt>--with-libdirs</tt><dd>Gives the directories in which libraries
|
---|
252 | should be sought. For example,
|
---|
253 | <tt>--with-libdirs=-L/usr/local/lib64</tt>.
|
---|
254 |
|
---|
255 | <dt><tt>--with-cca-chem-config</tt><dd>Specifies the config script for the
|
---|
256 | cca-chem-generic package (prerequisite for CCA components).
|
---|
257 |
|
---|
258 | </dl>
|
---|
259 |
|
---|
260 | If you would like to further customize your target directory,
|
---|
261 | you can edit <tt>src/lib/scconfig.h</tt> and <tt>lib/LocalMakefile</tt> to
|
---|
262 | suit your needs. The next time you run configure, these files and
|
---|
263 | all the makefiles will be overwritten.
|
---|
264 |
|
---|
265 | \subsection compilecca Notes on CCA Configuration
|
---|
266 |
|
---|
267 | <ul>
|
---|
268 | <li> Use the <tt>--enable-components</tt> flag to generate CCA components and enable
|
---|
269 | embedded frameworks within MPQC.
|
---|
270 | <li> The <tt>cca-chem-config</tt> script must be found in the user's path or
|
---|
271 | specified using the <tt>--with-cca-chem-config</tt>.
|
---|
272 | <li> To fully support runtime configuration of component applications,
|
---|
273 | compile using <tt>--enable-shared</tt>.
|
---|
274 | <li> Run <tt>make install_devel</tt> after compiling to install the <tt>sc-config</tt>
|
---|
275 | script (required by <tt>cca-chem-apps</tt>).
|
---|
276 | </ul>
|
---|
277 |
|
---|
278 | \section compilecomp Compilation
|
---|
279 |
|
---|
280 | Now you are ready to build the libraries and executables. Do this by
|
---|
281 | typing <tt>make</tt> in your target directory. If you are running on a
|
---|
282 | symmetric multi-processor, you can use GNU make to parallelize the
|
---|
283 | compilation. To compile four files at a time, type <tt>make -j4</tt>.
|
---|
284 | This feature works correctly with GNU make version 3.78.1 or later; for
|
---|
285 | older versions of GNU make use <tt>make JOBS=-j4</tt>.
|
---|
286 |
|
---|
287 | You can install the executables and data files with <tt>make install</tt>.
|
---|
288 |
|
---|
289 | You can install the libraries and header files with <tt>make
|
---|
290 | install_devel</tt>, however, <tt>make install</tt> must be also be run to
|
---|
291 | install the files needed for run-time support.
|
---|
292 |
|
---|
293 | \section compilecheck Checking the Compilation
|
---|
294 |
|
---|
295 | See \ref mpqcval for instructions for checking your compilation.
|
---|
296 |
|
---|
297 | */
|
---|