Skip to content

Commit

Permalink
README.md: Update build instructions
Browse files Browse the repository at this point in the history
  • Loading branch information
mmuetzel committed Oct 23, 2023
1 parent ec82439 commit 98429ea
Showing 1 changed file with 74 additions and 108 deletions.
182 changes: 74 additions & 108 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -331,8 +331,6 @@ Packages in SuiteSparse, and files in this directory:
author for all modules: Tim Davis
CHOLMOD/Modify module authors: Tim Davis and William W. Hager

CMakeLists.txt optional, to compile all of SuiteSparse. See below.

COLAMD column approximate minimum degree ordering. This is the
built-in COLAMD function in MATLAB.
authors (of the code): Tim Davis and Stefan Larimore
Expand Down Expand Up @@ -547,35 +545,24 @@ set all your paths at the start of each MATLAB session.
QUICK START FOR THE C/C++ LIBRARIES:
-----------------------------------------------------------------------------

Type the following in this directory (requires system priviledge to do the
`sudo make install`):

mkdir -p build && cd build
cmake ..
cmake --build .
sudo cmake --install .

All libraries will be created and installed into the default system-wide folder
(/usr/local/lib on Linux). All include files needed by the applications that
use SuiteSparse are installed into /usr/local/include (on Linux).
For Linux and Mac: type the following in this directory (requires system
priviledge to do the `sudo make install`):

To build only a subset of libraries, set `SUITESPARSE_ENABLE_PROJECTS` when
configuring with CMake. E.g., to build and install CHOLMOD and CXSparse
(including their dependencies), use the following commands:
make
sudo make install

mkdir -p build && cd build
cmake -DSUITESPARSE_ENABLE_PROJECTS="cholmod;cxsparse" ..
cmake --build .
sudo cmake --install .
All libraries will be created and copied into the default system-wide folder
(/usr/local/lib on Linux). All include files need by the applications that use
SuiteSparse are copied into /usr/local/include (on Linux).

For Windows (MSVC), import the `CMakeLists.txt` file into MS Visual Studio.
Be sure to specify the build type as Release; for example, to build SuiteSparse
on Windows in the command window, run:
For Windows, import each `*/CMakeLists.txt` file into MS Visual Studio.
A single top-level CMake script is being considered as a feature in the
future. Be sure to specify the build type as Release; for example, to
build `SuiteSparse_config` on Windows in the command window:

mkdir -p build && cd build
cd SuiteSparse_config/build
cmake ..
cmake --build . --config Release
sudo cmake --install .
cmke --build . --config Release

Be sure to first install all required libraries: BLAS and LAPACK for UMFPACK,
CHOLMOD, and SPQR, and GMP and MPFR for SPEX. Be sure to use the latest
Expand All @@ -586,10 +573,7 @@ see the SPEX user guide for details).
To compile the libraries and install them only in SuiteSparse/lib (not
/usr/local/lib), do this instead in the top-level of SuiteSparse:

mkdir -p build && cd build
cmake -DCMAKE_INSTALL_PREFIX=.. ..
cmake --build .
sudo cmake --install .
make local

If you add /home/me/SuiteSparse/lib to your library search path
(`LD_LIBRARY_PATH` in Linux), you can do the following (for example):
Expand All @@ -599,9 +583,10 @@ If you add /home/me/SuiteSparse/lib to your library search path

To change the C and C++ compilers, and to compile in parallel use:

cmake -DCMAKE_C_COMPILER=gcc -DCMAKE_CXX_COMPILER==g++ ..
CC=gcc CX=g++ JOBS=32 make

for example, which changes the compiler to gcc and g++.
for example, which changes the compiler to gcc and g++, and runs make with
'make -j32', in parallel with 32 jobs.

This will work on Linux/Unix and the Mac. It should automatically detect if
you have the Intel compilers or not, and whether or not you have CUDA.
Expand Down Expand Up @@ -644,87 +629,68 @@ Compilation options

You can set specific options for CMake with the command (for example):

cmake -DNPARTITION=ON -DNSTATIC=ON -DCMAKE_BUILD_TYPE=Debug ..
CMAKE_OPTIONS="-DNPARTITION=1 -DNSTATIC=1 -DCMAKE_BUILD_TYPE=Debug" make

That command will compile all of SuiteSparse except for CHOLMOD/Partition
Module (because of `-DNPARTITION=ON`). Debug mode will be used (the build
type). The static libraries will not be built (since `-DNSTATIC=ON` is set).

* `SUITESPARSE_ENABLE_PROJECTS`:

Semicolon separated list of projects to be built or `all`.
Default: `all` in which case the following projects are built:

`suitesparse_config;mongoose;amd;btf;camd;ccolamd;colamd;cholmod;cxsparse;ldl;klu;umfpack;rbio;spqr;graphblas;spex`

Additionally, this list is extended to include
`suitesparse_gpuruntime;gpuqrengine` if a working CUDA environment is
detected.

* `CMAKE_BUILD_TYPE`:

Default: "Release", use "Debug" for debugging.

* `ENABLE_CUDA`:

If set to true, CUDA is enabled for the project. Default: true for CHOLMOD
and SPQR; false otherwise.

* `CMAKE_INSTALL_PREFIX`:

Defines the install location (default on Linux is `/usr/local`). For example,
this command in the top level SuiteSparse folder will set the install
directory to `/stuff`, used by the subsequent "sudo cmake --install .":
```
cmake -DCMAKE_INSTALL_PREFIX=/stuff ..
sudo cmake --install .
```

* `NSTATIC`:

If true, static libraries are not built.
Default: false, except for GraphBLAS, which takes a long time to compile so
the default for GraphBLAS is true.

* `SUITESPARSE_CUDA_ARCHITECTURES`:

A string, such as "all" or "35;50;75;80" that lists the CUDA architectures to
use when compiling CUDA kernels with nvcc. The "all" option requires CMake
3.23 or later. Default: "52;75;80".

* `BLA_VENDOR`:

A string. Leave unset, or use "ANY" to select any BLAS library (the
default). Or set to the name of a BLA_VENDOR defined by FindBLAS.cmake.
See:
https://cmake.org/cmake/help/latest/module/FindBLAS.html#blas-lapack-vendors

* `ALLOW_64BIT_BLAS`:

If true, look for a 64-bit BLAS. If false: 32-bit only. Default: false.

* `NOPENMP`:

If true, OpenMP is not used. Default: false.

UMFPACK, CHOLMOD, SPQR, and GraphBLAS will be slow.

Note that BLAS and LAPACK may still use OpenMP internally; if you wish to
disable OpenMP in an entire application, select a single-threaded
BLAS/LAPACK.

WARNING: GraphBLAS may not be thread-safe if built without OpenMP (see the
User Guide for details).

* `DEMO`:
If true, build the demo programs for each package. Default: false.
Module (because of -DNPARTITION=1). Debug mode will be used (the build type).
The static libraries will not be built (since -DNSTATIC=1 is set).

CMAKE_BUILD_TYPE: Default: "Release", use "Debug" for debugging.

ENABLE_CUDA: if set to true, CUDA is enabled for the project.
Default: true for CHOLMOD and SPQR; false otherwise

LOCAL_INSTALL: if true, "cmake --install" will install
into SuiteSparse/lib and SuiteSparse/include.
if false, "cmake --install" will install into the
default prefix (or the one configured with
CMAKE_INSTALL_PREFIX).
Default: false

CMAKE_INSTALL_PREFIX: defines the install location (default on Linux is
/usr/local). For example, this command in the top
level SuiteSparse folder will set the install directory
to "/stuff", used by the subsequent "sudo make install":

CMAKE_OPTIONS="-DCMAKE_INSTALL_PREFIX=/stuff" make
sudo make install

NSTATIC: if true, static libraries are not built.
Default: false, except for GraphBLAS, which
takes a long time to compile so the default for
GraphBLAS is true. For Mongoose, the NSTATIC setting
is treated as if it always false, since the mongoose
program is built with the static library.

SUITESPARSE_CUDA_ARCHITECTURES: a string, such as "all" or
"35;50;75;80" that lists the CUDA architectures to use
when compiling CUDA kernels with nvcc. The "all"
option requires cmake 3.23 or later.
Default: "52;75;80".

BLA_VENDOR a string. Leave unset, or use "ANY" to select any BLAS
library (the default). Or set to the name of a
BLA_VENDOR defined by FindBLAS.cmake. See:
https://cmake.org/cmake/help/latest/module/FindBLAS.html#blas-lapack-vendors

ALLOW_64BIT_BLAS if true: look for a 64-bit BLAS. If false: 32-bit only.
Default: false.

NOPENMP if true: OpenMP is not used. Default: false.
UMFPACK, CHOLMOD, SPQR, and GraphBLAS will be slow.
Note that BLAS and LAPACK may still use OpenMP
internally; if you wish to disable OpenMP in an entire
application, select a single-threaded BLAS/LAPACK.
WARNING: GraphBLAS may not be thread-safe if built
without OpenMP (see the User Guide for details).

DEMO if true: build the demo programs for each package.
Default: false.

Additional options are available within specific packages:

* `NCHOLMOD`:

If true, UMFPACK and KLU do not use CHOLMOD for additional (optional)
ordering options.
NCHOLMOD if true, UMFPACK and KLU do not use CHOLMOD for
additional (optional) ordering options

CHOLMOD is composed of a set of Modules that can be independently selected;
all options default to false:
Expand Down

0 comments on commit 98429ea

Please sign in to comment.