Skip to main content

FV3Config is used to configure and manipulate run directories for FV3GFS.

Project description

FV3Config

https://readthedocs.org/projects/fv3config/badge/?version=latest https://circleci.com/gh/VulcanClimateModeling/fv3config.svg?style=svg

FV3Config is used to configure and manipulate run directories for FV3GFS.

  • Free software: BSD license

Basic usage

import fv3config

with open("config.yml", "r") as f:
    config = fv3config.load(f)
fv3config.write_run_directory(config, './rundir')

config is a configuration dictionary which contains namelists, input data specifications, and other options. It can be edited just like any dictionary.

For more in-depth usage, please refer to the documentation. This can be generated with make docs.

History

Latest

v0.7.1 (2021-03-18)

Bug Fixes:

  • replace a couple instances of yaml.dump/load with fv3config.dump/load

v0.7.0 (2021-03-17)

Breaking changes:

  • Modify the serialization APIs

  • add fv3config.load/dump

  • remove fv3config.config_to_yaml and fv3config.config_from_yaml

Bug Fixes:

  • use DiagTable aware serialization routines inside the CLIs

v0.6.1 (2021-02-23)

Minor changes:

  • don’t specify a consistency in the fsspec.filesystem instantiation

v0.6.0 (2021-02-22)

Major changes:

  • add DiagTable class with associated DiagFileConfig and DiagFieldConfig dataclasses.

  • make fv3config.config_to_yaml a public function.

  • update fv3config.config_to_yaml and fv3config.config_from_yaml to go between fv3config.DiagTable and dict types as necessary when serializing/deserializing

  • write_run_directory provisions necessary patch_files for config if the fv_core_nml.nudge option is set to True.

v0.5.2 (2021-02-04)

  • Add logging to write_run_directory command

v0.5.1

  • Fix formatting of this changelog for PyPI

v0.5.0

Breaking changes:

  • enable_restart function now requires an initial_conditions argument. It also sets force_date_from_namelist to False.

Major changes:

  • a new public function fv3config.get_bytes_asset_dict

  • a new command line interface write_run_directory

  • removed integration tests for run_docker and run_native which actually executed the model

  • all tests are now offline, using a mocked in-memory gcsfs to represent remote communication.

  • add a Dockerfile to produce a lightweight image with fv3config installed

  • Add new public functions fv3config.get_nudging_assets and fv3config.update_config_for_nudging.

  • Add CLI entry points for enable_restart and update_config_for_nudging.

Minor changes:

  • updated create_rundir example to accept external arguments

  • refactor get_current_date function to not require the path to the INPUT directory.

v0.4.0 (2020-07-09)

Major changes:

  • the old “default” data options are removed

  • orographic_forcing is now a required configuration key

  • get_default_config() is removed, with a placeholder which says it was removed

  • ensure_data_is_downloaded is removed, with a placeholder which says it was removed

v0.3.2 (2020-04-16)

Major changes:

  • filesystem operations now manually backoff with a 1-minute max time on RuntimeError (which gcsfs often raises when it shouldn’t) and gcsfs.utils.HttpError

  • put_directory now makes use of a thread pool to copy items in parallel.

Minor changes:

  • run_docker now works when supplying an outdir on google cloud storage

  • put_directory is now marked as package-private instead of module-private

v0.3.1 (2020-04-08)

Major changes:

  • Add get_timestep and config_from_yaml functions

Minor changes:

  • Allow config_to_yaml to write to remote locations

  • Control whether outputs are logged to console or not in run_kubernetes, run_native, and run_docker.

Breaking changes

  • Print stderr and stdout to the console by default when using fv3run. Use the –capture-output command-line flag to enable the previous behavior.

v0.3.0 (2020-04-03)

Major changes:

  • Added –kubernetes command-line flag to output a kubernetes config yaml to stdout

Minor changes:

  • Added the flag --mca btl_vader_single_copy_mechanism none to mpirun in fv3run to mpirun in fv3run

  • Add ReadTheDocs configuration file

  • Do not require output dir and fv3config to be remote in run_kubernetes

  • Fix bug when submitting k8s jobs with images that have an “_” in them

Breaking changes

  • Refactored run_kubernetes and run_docker to call run_native via a new API serializing their args/kwargs as json strings. The fv3config version in a docker image must be greater than or equal inside a container to outside, or a silent error will occur.

  • When output location is set to a local path, the job now runs in that output location instead of in a temporary directory which then gets copied. This is done both to reduce copying time for large jobs, and to improve visibility of model behavior while running.

0.2.0 (2020-01-27)

  • Began tagging version commits

0.1.0 (2019-10-11)

  • Initial pre-alpha release

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

fv3config-0.7.1.tar.gz (62.4 kB view details)

Uploaded Source

Built Distribution

fv3config-0.7.1-py2.py3-none-any.whl (43.9 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file fv3config-0.7.1.tar.gz.

File metadata

  • Download URL: fv3config-0.7.1.tar.gz
  • Upload date:
  • Size: 62.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.14.0 pkginfo/1.7.0 requests/2.25.1 setuptools/47.1.0 requests-toolbelt/0.9.1 tqdm/4.57.0 CPython/3.8.5

File hashes

Hashes for fv3config-0.7.1.tar.gz
Algorithm Hash digest
SHA256 8a3916c2c9a034b197e1036eaa1a4df77ba10a6790a83e6e3758c0ac74ffe761
MD5 6ca3ae1d31f96076a1b0d6ffc9a24eb2
BLAKE2b-256 aa503713aab5b7b05614dba778be7f7a2356f530124ea72d819ef56ced3e3c48

See more details on using hashes here.

File details

Details for the file fv3config-0.7.1-py2.py3-none-any.whl.

File metadata

  • Download URL: fv3config-0.7.1-py2.py3-none-any.whl
  • Upload date:
  • Size: 43.9 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.14.0 pkginfo/1.7.0 requests/2.25.1 setuptools/47.1.0 requests-toolbelt/0.9.1 tqdm/4.57.0 CPython/3.8.5

File hashes

Hashes for fv3config-0.7.1-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 0d4155ce24a66bbdaf8b962f6a7b50ce7464df8cfc93eb2e04a0ad574176fb97
MD5 7e2e0823acce409231dec8e5f8be0e7f
BLAKE2b-256 911643192d942865440a182266476b923a6e3eeb3f038d1079fe13694409ff48

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page