This is a public repo for SUEWS source code and documentation.
Documentation site: https://suews.readthedocs.io/
Documentation source: docs
folder in this repo
git submodule init
git submodule update
Then source code of SPARTACUS will be loaded into `SUEWS-SourceCode/ext_lib/spartacus-surface`
*Note: if a `permission denied` error occurs, one usually needs to fix the SSH connection to GitHub by following the [official guide here](https://docs.github.com/en/github/authenticating-to-github/connecting-to-github-with-ssh).*
2. Configure mamba environment by:
```shell
mamba env create -f env.yml
This will create a new environment named suews-dev
with all the required packages installed.
Activate the environment by:
make activate suews-dev
Compile SUEWS
4.1 compile the code and perform all tests
make
4.2 only compile the code
make dev
This will install a python package supy-driver
and supy
into the current environment (i.e., suews-dev
).
Also, several command-line tools will be installed under bin
folder, which can be used to perform SUEWS simulations:
suews-run
: the main SUEWS binarysuews-convert
: a tool to convert SUEWS input files from old format to new format
the usage of both of which can be checked by --help
option (e.g., suews-run --help
).supy
is installed by:
pip show supy
[!NOTE] the following is deprecated and will be updated
GDB is a generic debugging tool used along with gfortran. Here are some tips to debug SUEWS code:
Recent macOS (since High Sierra) introduces extra security procedures for system level operations that makes installation GDB more tedious than before.
The best practice, in TS's opinion, to avoid hacking your macOS, is to use Linux docker images with gfortran & gdb installations: e.g., alpine-gfortran
(otherwise, this guide might be useful for installation of GDB on macOS; also run set startup-with-shell off
inside GDB before run
the debuggng process)
Once the docker image is installed, simply run this from the SUEWS root folder for debugging:
docker run --rm -it -v $(pwd):/source sunt05/alpine-gfortran /bin/bash
which will mount the current SUEWS
directory to docker's path /source
and enter the interactive mode for debugging.
Makefile
under SUEWS-SourceCode
by removing the #
after the equal sign =
:FCNOOPT = -O0
FFLAGS = -O3 $(STATIC) $(FCDEBUG) -Wall -Wtabs -fbounds-check -cpp \
-Wno-unused-dummy-argument -Wno-unused-variable
fully clean and recompile SUEWS
:
make clean; make
copy the recompiled SUEWS
binary into your SUEWS testing folder (e.g., Test/BaseRun/2019a
) and load it into GDB:
gdb SUEWS
run
then you should have stack info printed out by GDB if any runtime error occurs.
More detailed GDB tutorial can be found here.