Metadata-Version: 2.1
Name: palmmeteo
Version: 2.6.4
Summary: PALM-meteo: processor of meteorological input data for the PALM model system.
Author-email: Pavel Krc <krc@cs.cas.cz>
License: GPL-3.0-or-later
Project-URL: Homepage, https://github.com/PALM-tools/palmmeteo
Project-URL: Issues, https://github.com/PALM-tools/palmmeteo/issues
Classifier: Programming Language :: Python :: 3
Classifier: Operating System :: POSIX :: Linux
Classifier: Operating System :: Microsoft :: Windows
Classifier: Development Status :: 4 - Beta
Requires-Python: >=3.10
Description-Content-Type: text/markdown
Provides-Extra: aladin
Provides-Extra: geostrophic_wind
Provides-Extra: vinterp_metpy
License-File: LICENSE

# PALM-meteo: processor of meteorological input data for the PALM model system                  {#mainpage}

PALM-meteo is an advanced and modular tool to create PALM's *dynamic driver*
with initial and boundary conditions (IBC) and other time-varying data,
typically using (but not limited to) outputs from mesoscale models. It is
a successor to multiple older projects for PALM dynamic drivers, most
importantly the deprecated
[WRF-interface](https://gitlab.palm-model.org/dynamic_driver/wrf_interface)
project.

The documentation for PALM-meteo is available at
https://palm-tools.github.io/palmmeteo/.

## Functionality

The PALM-meteo workflow consists of six _stages_. Normally, they are all
executed sequentially, but it is possible to stop the execution after any stage
and restart it later (see also [Running PALM-meteo](docs/pages/running.md)).

1. **Configuration** (`check_config`): Loads and validates user configuration.

2. **Domain and model set-up** (`setup_model`): setting up basic items such as
   the geometry of the PALM model domain.  Currently this requires providing
   the already prepared PALM *static driver*.

3. **Input data loading** (`import_data`): selection of requested variables,
   area selection, transformation and/or unit conversion where required.
   Certain input variables are also temporally disagregated.

4. **Horizontal interpolation** (`hinterp`) from the input model grid to PALM
   grid.  Includes geographic projection conversion where required. Models with
   traditional rectangular grid are regridded using bilinear interpolation, the
   ICON model with the icosahedral grid uses Delaunay triangulation and
   barycentric interpolation.

5. **Vertical interpolation** (`vinterp`) from input model levels (which may be
   terrain-following, isobaric, eta, hybrid etc.) to PALM model levels
   (altitude-based). Part of this process is terrain matching, as the
   high-resolution PALM terrain may differ, even significantly, from the input
   model terrain. This process includes configurable vertical adaptation, where
   the lowest input layer is shifted to match the PALM terrain while in the
   higher layers, the vertical shifts are progressively smaller until they
   reach the _transition level_, above which they are not shifted at all.

6. **Output generation** (`write`) creates the final PALM dynamic driver. Final
   adjustments are performed here, notably the mass balancing which is
   performed on all boundaries (respecting terrain on lateral boundaries), so
   that the PALM's internal mass balancing (which is performed only on the top
   boundary as a last resort) is not overused.

Currently PALM-meteo supports these meteorological inputs:

### Meteorological IBC
- WRF
- ICON
- Aladin
- Synthetic inputs (detailed profile specification etc.)

### Radiation inputs (optional)
- WRF
- ICON
- Aladin

### Chemical IBC (optional)
- CAMx
- CAMS

PALM-meteo is higly modular and more input sources will be likely added in the
future. A detailed technical description will be made available in the upcoming
scientific paper.

## Installation

There are three basic ways to install PALM-meteo.

### Method 1: Simple minimal installation using PIP

PALM-meteo is available in PyPI and it can be installed with the simple
command:

    pip3 install palmmeteo

This will also install the `pmeteo` command for running PALM-meteo.
Depending on your operating system and environment, you may want to create
a virtual environment first, or use the `--user` option, or use
[pipx](https://pipx.pypa.io/) instead of pip.

However, this method will install only the bare minimum to run PALM-meteo,
without documentation and tests, so it is only recommended for experienced
users who want a quick installation.

### Method 2: Full in-place installation with a virtual environment {#method2}

This is the recommended method for most users.

1. Make sure that you have python3, pip, and python-venv installed and available.
   This is operating system dependent.
2. Download and extract PALM-meteo into a directory of your choice. If you have
   already installed the PALM model system, then PALM-meteo is already
   extracted under `packages/dynamic_driver/palm_meteo`, albeit probably not in
   the newest version. Or you can download PALM-meteo from the
   [PALM gitlab server](https://gitlab.palm-model.org/dynamic_driver/palm_meteo)
   or from
   [GitHub](https://github.com/PALM-tools/palmmeteo/releases).
3. From within the PALM-meteo install directory, run `./setup`. This will
   create a new virtual environment, install PALM-meteo with all dependencies
   and create a symlink to the `pmeteo` command (which enables the virtual
   environment automatically).

### Method 3: Advanced installation for developers

1. Clone the PALM-meteo git repository.
2. Create and enable your own virtual environment if you prefer.
3. From within the PALM-meteo install directory, run `./setup_novenv`. This will
   install PALM-meteo dependencies and create a simple `pmeteo` running script.

### Testing

PALM-meteo comes with integration tests supplied.  When installed using [Method
2](#method2), the install script performs the tests at the end of a successful
instalation. You may also exectute them at any time from the PALM-meteo install
directory using the command

    tests/integration_tests/all_tests.sh

or for indivudal tests:

    tests/integration_tests/test_XX_NAMEOFTEST.sh

You may also examine the directory `tests/integration_tests/simple_wrf` as
a reference WRF case for PALM-meteo.

### Optional dependencies

Some plugins or extra functionalities have optional dependencies which are not
part of the main installation as they are often not used. In the Method 1,
you may enable them by using
`pip3 install palmmeteo[extra_functionality]`
for these extra functionalities: `vinterp_metpy` for the legacy MetPy vertical
interpolation, `geostrophic_wind` or `aladin`. With the other install methods
you need to manually install the Python packages listed in
`pyproject.toml`.

It is also possible to use the fastest method for vertical interpolation
(see [configuration](docs/pages/configuration.md)) which uses natively compiled
Fortran code. To do this, you must first compile it by running this command
within the `palmmeteo` directory:

    f2py -c -m vinterp_native vinterp_native.f90

## Usage

For each dynamic driver, a *YAML* configuration file needs to be prepared
(typically one per case, although it is possible to combine more files). This
file uses sensible defaults for most options, so it does not need to be very
long, as is demonstrated by the supplied file `example.yaml`. However for the
beginners it is best to start by making a copy of the file `template.yaml`,
which contains all user-selectable options with their defaults and
documentation, and modifying it accordingly. See
[PALM-meteo configuration](docs/pages/configuration.md).

### Basic model configuration

The main part of configuration is selecting a single or multiple *tasks* by
adding a list item in the `tasks:` configuration section.  Selecting a task
means just telling what PALM-meteo what it has to do, which typically involves
creating IBC and/or other PALM inputs using the selected method, such as using
a specific input model.

These are the currently supported tasks (obviously many of them are mutually
 exclusive):
 
- `wrf`: Create IBC from WRF model outputs.
- `wrf_rad`: Create PALM radiation inputs from WRF model outputs (typically
  *AUXHIST* outputs with potentially different time step from standard
  *WRFOUT*).
- `icon`:    Create IBC from ICON outputs in the *NetCDF* format.
- `aladin`:  Create IBC from Aladin outputs in the *grib* format.
- `camx`:    Create chemistry IBC from CAMx model outputs.
- `cams`:    Create chemistry IBC from CAMS model outputs.

When the specified task(s) are selected, the task configuration mechanism
enables the required plugins and pulls in the respective task-specific
configuration defauls, which may be overwritten within the configuration file.

### Running the model

With a prepared configuration file such as `myconfig.yaml`, simply run

    ./pmeteo -c myconfig.yaml

in the project directory. See [Running PALM-meteo](docs/pages/running.md) for
more information.

## Extending PALM-meteo

In order to add new input types or processing methods, PALM-meteo can be easily
extended with user plugins. For documentation, see the
[Developer guide](docs/pages/extending.md).

## License and authors

PALM-meteo is distributed under the GNU GPL v3+ license (see the `LICENSE`
file).  It was created by the Institute of Computer Science of the Czech
Academy of Sciences (ICS CAS) with contributions by the Charles University
in Prague (MFF UK), the Czech Hydrometeorological Institute (CHMI) and the Deutsche
Wetterdienst (DWD).

### Acknowledgenments

PALM-meteo was created with the support of these projects:

- [TURBAN: Turbulent-resolving urban modeling of air quality and thermal comfort](https://project-turban.eu/)
  (Technology Agency of the Czech Republic
  [project TO01000219](https://starfos.tacr.cz/en/projekty/TO01000219))
- [CARMINE – Climate-Resilient Development Pathways in Metropolitan Regions of Europe](https://carmine-project.eu/)
  (European Commission
  [project 101137851](https://cordis.europa.eu/projects/101137851))
