From 56c2aa8bd67f91c02ca431754879b2e14eccb4c2 Mon Sep 17 00:00:00 2001 From: Justin Laughlin Date: Tue, 6 Aug 2024 17:05:22 -0700 Subject: [PATCH] lots of rewriting install.md, and a little bit of readme.md. WIP --- INSTALL.md | 70 +++++++++++++++++++++++++++++++++++++----------------- README.md | 13 +++++----- 2 files changed, 55 insertions(+), 28 deletions(-) diff --git a/INSTALL.md b/INSTALL.md index 916baa95..6c2f1c5f 100644 --- a/INSTALL.md +++ b/INSTALL.md @@ -1,16 +1,45 @@ # Installation Guide -Most users will be fine with the default `pip` install: +## Basic install + +Most users will be fine using the binary bundled in the default `pip` install: ```shell pip install mfem ``` -or +or, to install from source, ```shell pip install mfem --no-binary mfem ``` -This will install a *serial* version of `MFEM` and the `PyMFEM` wrapper without any additional dependencies. +By default, the installation will download and install a *serial* version of `MFEM`. + +## `pip install` vs `python setup.py install` +Most of the options for PyMFEM can be used directly when installing via `python setup.py install`, e.g. +```shell +python setup.py install --with-parallel +``` + +## Parallel (MPI) support +To build both serial and parallel version of `MFEM` and wrapper use the `--with-parallel` flag: +```shell +pip install mfem --with-parallel +``` + +Note: this option turns on building `metis` and `Hypre` + +## Commonly used flags + +| Flag | Description | +|------|-------------| +| `--with-parallel` | Install both serial and parallel versions of `MFEM` and the wrapper
(note: this option turns on building `metis` and `hypre`) | +| `--mfem-branch=` | Download/install MFEM using a specific reference (`git` `branch`, `hash`, or `tag`) | +| `--mfem-source=` | Specify a local version of MFEM | +| `--mfem-prefix ` | The location of the MFEM library. `libmfem.so` needs to be found in `/lib` | +| `--mfems-prefix `| (optional) Specify serial MFEM location separately | +| `--mfemp-prefix `| (optional) Specify parallel MFEM location separately | + +## Advanced options PyMFEM has many options for installation, including: - Serial and parallel (MPI) wrappers @@ -36,13 +65,8 @@ In order to see the full list of options, use python setup.py install --help ``` -In below, for the brevity, examples are mostly shown using `python setup.py install` convention. -When using PIP, each option needs to be passed using `--install-option`. - -## Parallel MFEM -`--with-parallel` : build both serial and parallel version of `MFEM` and wrapper - -Note: this option turns on building `metis` and `Hypre` +In below, for brevity, examples are mostly shown using `python setup.py install` convention. +When using pip, each option needs to be passed using `--install-option`. ## Suitesparse `--with-suitesparse` : build MFEM with `suitesparse`. `suitesparse` needs to be installed separately. @@ -82,11 +106,13 @@ Note: this option builds GSlib `--with-libceed` : build MFEM with libceed Note: this option builds libceed -## Specify compilers -`--CC` c compiler -`--CXX` c++ compiler -`--MPICC` mpic compiler -`--MPICXX` mpic++ compiler +## Specifying compilers +| Flag | Description | +|------|--------| +| `--CC` | c compiler | +| `--CXX` | c++ compiler | +| `--MPICC` | mpic compiler | +| `--MPICXX` | mpic++ compiler | (example) Using Intel compiler @@ -110,13 +136,13 @@ python setup.py install --mfem-branch=master These options are used to link PyMFEM wrapper with existing MFEM library. We need `--mfem-source` and `--mfem-prefix` -`--mfem-source ` : the location of MFEM source used to build MFEM - -`--mfem-prefix ` : the location of MFEM library. libmfem.so needs to be found in `/lib` - -`--mfems-prefix ` : (optional) specify serial MFEM location separately +| Flag | Description | +|----------------------------|-------------------------------------------------------------------| +| `--mfem-source ` | The location of MFEM source used to build MFEM | +| `--mfem-prefix ` | The location of the MFEM library. `libmfem.so` needs to be found in `/lib` | +| `--mfems-prefix `| (optional) Specify serial MFEM location separately | +| `--mfemp-prefix `| (optional) Specify parallel MFEM location separately | -`--mfemp-prefix ` : (ooptional)specify parallel MFEM location separately ## Blas and Lapack --with-lapack : build MFEM with lapack @@ -169,6 +195,6 @@ python setup.py install --with-parallel --skip-ext --skip-swig --mfem-branch="ma ## Other options `--unverifiedSSL` : This addresses error relating SSL certificate. Typical error message is - "" + `` diff --git a/README.md b/README.md index df844712..ac293a66 100644 --- a/README.md +++ b/README.md @@ -11,7 +11,7 @@ By default, "pip install mfem" downloads and builds the serial version of MFEM a Additionally, the installer supports building MFEM with specific options together with other external libraries, including MPI version. ## Install -```bash +```shell pip install mfem # binary install is available only on linux platforms (Py36-310) pip install mfem --no-binary mfem # install serial MFEM + wrapper from source @@ -24,12 +24,12 @@ and build parallel version of MFEM library (linked with Metis and Hypre) and installs under /mfem. See also, docs/install.txt ### Using pip -```bash -$ pip install mfem --install-option="--with-parallel" +```shell +pip install mfem --install-option="--with-parallel" ``` ### Build from local source file -```python +```shell # Download source and build $ pip download mfem --no-binary mfem (expand tar.gz file and move to the downloaded directory) or clone this repository @@ -59,8 +59,9 @@ $ python setup.py install --help ``` ## Usage -This example solves the Poisson equation, $\nabla \cdot (\alpha \nabla u) = f$, in a square and plots the result -with matplotlib (modified from `ex1.cpp`). +This example (modified from `ex1.cpp`) solves the Poisson equation, +$$\nabla \cdot (\alpha \nabla u) = f$$ +in a square and plots the result using matplotlib. Use the badge above to open this in Binder. ```python