diff --git a/.github/workflows/run_all_quickbuilds.yml b/.github/workflows/run_all_quickbuilds.yml new file mode 100644 index 0000000000..a153aa0064 --- /dev/null +++ b/.github/workflows/run_all_quickbuilds.yml @@ -0,0 +1,81 @@ +name: 'run all quickbuilds' +on: + workflow_dispatch: + +jobs: + setup: + runs-on: ubuntu-latest + container: + image: hkershaw/dart-dep-external:2.0 + options: "--cap-add=SYS_PTRACE" + outputs: + matrix: ${{ steps.matrix.outputs.value }} + steps: + - uses: actions/checkout@v4 + - id: matrix + run: | + git config --global --add safe.directory /__w/${{ github.event.repository.name }}/${{ github.event.repository.name }} + DART=$(git rev-parse --show-toplevel) + files_to_process=( $(find $DART -executable -type f -name quickbuild.sh | sed -E 's#(\./|quickbuild\.sh)##g') ) + joined_items="" + for item in "${files_to_process[@]}"; do + if [[ $item == *"template"* ]]; then + continue # template model not for compiling + fi + if [[ $item == *"/var/"* ]] || [[ $item == *"/gps/"* ]]; then + # skipping these converters, out of the box quickbuild.sh fails + # var needs wrf files + # gps need prepbuffr bufrlib.a to be built + continue + fi + # Append the quoted item and a comma to the string + stripped_item=${item#/__w/${{ github.event.repository.name }}/${{ github.event.repository.name }}/} # removes /__w/DART/DART + echo $stripped_item + joined_items+="\"$stripped_item\"," + done + + # Remove the trailing comma from the last item + joined_items="${joined_items%,}" + + echo "value=[ $joined_items ]" >> $GITHUB_OUTPUT + shell: bash + build: + needs: [ setup ] + runs-on: ubuntu-latest + container: + image: hkershaw/dart-dep-external:2.0 + options: "--cap-add=SYS_PTRACE" + strategy: + fail-fast: false + matrix: + value: ${{fromJSON(needs.setup.outputs.matrix)}} + steps: + - name: Checkout repo + uses: actions/checkout@v4 + - name: Set checked out repo as a safe git directory + run: git config --global --add safe.directory /__w/${{ github.event.repository.name }}/${{ github.event.repository.name }} + - name: Creating Makefile template + run: | + cd build_templates + sed -i 's|exec '\''make'\'', '\''-f'\'', \$opt_m if \$opt_x;|exec '\''make'\'', '\''-j'\'', '\''4'\'', '\''-f'\'', \$opt_m if \$opt_x;|' mkmf + case ${{ matrix.value }} in + *quikscat* | *GSI2DART* ) + cp /home/mkmf.template.quikscat.gfortran mkmf.template + ;; + *AIRS*) + cp /home/mkmf.template.AIRS.gfortran mkmf.template + ;; + *GMI* | *GOES* | *forward_operators* | *NSIDC* ) + cp /home/mkmf.template.rttov.gfortran mkmf.template + ;; + *) + cp mkmf.template.gfortran mkmf.template + echo 'FFLAGS = -g -Wuninitialized -Wunused -ffree-line-length-none -fbounds-check -fbacktrace -ffpe-trap=invalid,zero,overflow $(INCS)' >> mkmf.template + ;; + esac + shell: bash + - name: Run quickbuild.sh script + run: | + cd ${{ matrix.value }} + ./quickbuild.sh + shell: bash diff --git a/CHANGELOG.rst b/CHANGELOG.rst index e1dc25ad49..d50c46d295 100644 --- a/CHANGELOG.rst +++ b/CHANGELOG.rst @@ -22,6 +22,13 @@ individual files. The changes are now listed with the most recent at the top. +**July 11 2024 :: Bgrid documentation and scripting fix. Tag v11.5.1** + +- Updated Bgrid documentation and removed outdated scripts and files +- Fixed obs_diag rank histogram documentation links +- Improved inflation file documentation +- GitHub action for running all quickbuilds in DART + **May 16 2024 :: WRF v4. Tag v11.5.0** - WRF-DART and WRF-DART Tutorial updated to WRFv4. Note, not backwards compatible with WRFv3.9. diff --git a/assimilation_code/programs/obs_diag/threed_cartesian/obs_diag.rst b/assimilation_code/programs/obs_diag/threed_cartesian/obs_diag.rst index 295a80caab..5e8b7a4da4 100644 --- a/assimilation_code/programs/obs_diag/threed_cartesian/obs_diag.rst +++ b/assimilation_code/programs/obs_diag/threed_cartesian/obs_diag.rst @@ -73,7 +73,7 @@ the quantity (for every variable, every level, every region) in a single matlab figure window - and creates a series of .ps files with multiple pages for each of the figures. The directory gets cluttered with them. The rank histogram information in ``obs_diag_output.nc`` can easily be plotted with -`ncview `__ (left), +`ncview`_. (left), a free third-party piece of software or with ``plot_rank_histogram.m`` (right). See the `Rank histograms`_ section for more information and links to instructions. @@ -552,10 +552,9 @@ Please note: +-----------+----------------------------------------------------------------------------------------------------------+ | |image3| | `Instructions for viewing the rank histogram with | -| | ncview `__. | +| | ncview `__. | +-----------+----------------------------------------------------------------------------------------------------------+ -| |image4| | `Instructions for viewing the rank histogram with | -| | Matlab `__. | +| |image4| | :ref:`Instructions for viewing the rank histogram with Matlab`. | +-----------+----------------------------------------------------------------------------------------------------------+ "trusted" observation types @@ -746,7 +745,7 @@ portion of the run-time output: variable in the netCDF file. | Now that you have the ``obs_diag_output.nc``, you can explore it with ``plot_profile.m, plot_bias_xxx_profile.m, or plot_rmse_xxx_profile.m``, - rank histograms with `ncview `__ or ``plot_rank_histogram.m``. + rank histograms with `ncview`_ or ``plot_rank_histogram.m``. References ---------- @@ -768,3 +767,6 @@ N/A :width: 600px .. |image5| image:: ../../../../guide/images/RAD_T_trusted_bias_evolution.png :width: 600px + +.. _ncview: https://cirrus.ucsd.edu/ncview/ + diff --git a/assimilation_code/programs/obs_diag/threed_sphere/obs_diag.rst b/assimilation_code/programs/obs_diag/threed_sphere/obs_diag.rst index e18fc89bdc..efb4593ec3 100644 --- a/assimilation_code/programs/obs_diag/threed_sphere/obs_diag.rst +++ b/assimilation_code/programs/obs_diag/threed_sphere/obs_diag.rst @@ -1,3 +1,5 @@ +.. _obs-diag-threed-sphere: + PROGRAM ``obs_diag`` (for observations that use the threed_sphere location module) ================================================================================== @@ -77,7 +79,7 @@ the quantity (for every variable, every level, every region) in a single matlab figure window - and creates a series of .ps files with multiple pages for each of the figures. The directory gets cluttered with them. The rank histogram information in ``obs_diag_output.nc`` can easily be plotted with -`ncview `__ (left), +`ncview`_. (left), a free third-party piece of software or with ``plot_rank_histogram.m`` (right). See the `Rank histograms`_ section for more information and links to instructions. @@ -536,10 +538,9 @@ Please note: +-----------+----------------------------------------------------------------------------------------------------------+ | |image3| | `Instructions for viewing the rank histogram with | -| | ncview `__. | +| | ncview `__. | +-----------+----------------------------------------------------------------------------------------------------------+ -| |image4| | `Instructions for viewing the rank histogram with | -| | Matlab `__. | +| |image4| | :ref:`Instructions for viewing the rank histogram with Matlab`. | +-----------+----------------------------------------------------------------------------------------------------------+ "trusted" observation types @@ -730,7 +731,7 @@ portion of the run-time output: variable in the netCDF file. | Now that you have the ``obs_diag_output.nc``, you can explore it with ``plot_profile.m, plot_bias_xxx_profile.m, or plot_rmse_xxx_profile.m``, - rank histograms with `ncview `__ or ``plot_rank_histogram.m``. + rank histograms with `ncview`_ or ``plot_rank_histogram.m``. References ---------- @@ -752,3 +753,6 @@ N/A :width: 600px .. |image5| image:: ../../../../guide/images/RAD_T_trusted_bias_evolution.png :width: 600px + +.. _ncview: https://cirrus.ucsd.edu/ncview/ + diff --git a/conf.py b/conf.py index 6b2fdb2ab3..db0041097f 100644 --- a/conf.py +++ b/conf.py @@ -21,7 +21,7 @@ author = 'Data Assimilation Research Section' # The full version, including alpha/beta/rc tags -release = '11.5.0' +release = '11.5.1' root_doc = 'index' # -- General configuration --------------------------------------------------- diff --git a/guide/matlab-observation-space.rst b/guide/matlab-observation-space.rst index 853fc535d7..d1202a77c7 100644 --- a/guide/matlab-observation-space.rst +++ b/guide/matlab-observation-space.rst @@ -108,7 +108,10 @@ multiple axes on a single figure. |two experiments profile example| ----------------------------------------- +.. _plotRankHistogram: + +plot_rank_histogram +------------------- `plot_rank_histogram.m `__ will create rank histograms for any variable that has that information present in diff --git a/models/bgrid_solo/readme.rst b/models/bgrid_solo/readme.rst index 7673f5a466..84bba0f960 100644 --- a/models/bgrid_solo/readme.rst +++ b/models/bgrid_solo/readme.rst @@ -27,10 +27,39 @@ model time step to maintain stability for larger model grids. The model state variables are the gridded surface pressure, temperature, and u and v wind components. -The ``bgrid_solo`` directory has a ``work/workshop_setup.csh`` script that compiles -and runs an example. This example is intended to demonstrate that the same -process used for a low-order model may be used for a much more -complex model and generates output for state-space or observation-space diagnostics. +In the ``DART/models/bgrid_solo/work`` directory, an example "perfect model" experiment +can be run in which a bgrid_solo netcdf file is produced and then perturbed +to get an ensemble. This example is intended to demonstrate that the same +process used for a low-order model may be used for a much more complex model +and generates output for state-space or observation-space diagnostics. + +The steps to run this example are as follows: + +1. | ``./quickbuild.sh`` (or ``quickbuild.sh nompi`` if you are not building with mpi) + | Builds all DART executables and ``perfect_input.nc`` from the cdl file + ``perfect_input.cdl`` + +2. | ``./perfect_model_obs`` + | Reads in an observation sequence file which has only observation definitions + (``obs_seq.in``) and generates synthetic observation values from a hindcast + model (``perfect_input.nc``). Results in output state vector file (``perfect_output.nc``) + and an output observation sequence file (``obs_seq.out``) to be assimilated by ``filter`` + +3. | ``cp perfect_output.nc filter_input.nc`` + | Copies the output from the ``perfect_model_obs`` program to the input file for + the ``filter`` program + +4. | In ``work/input.nml``, set ``perturb_from_single_instance = .true.`` in the + ``&filter_nml`` + | This setting causes filter to perturb a single restart file to generate an + ensemble + +5. | ``./filter`` + | Runs the assimilation program, resulting in three main output files: + | ``preassim.nc`` - the state of all ensemble members prior to the assimilation + (i.e. the forecast with any prior inflation applied) + | ``analysis.nc`` - the state of all ensemble members after the assimilation + | ``obs_seq.final`` - the ensemble members' estimate of the observations. Some examples of ways in which this model can be configured and modified to test DART assimilation capabilities are documented in Anderson et al. (2005). [3]_ @@ -42,21 +71,41 @@ interactive user input and create a text file that can be piped into program examples for users who are interested in designing their own custom obs_sequence files. -Program ``column_rand`` creates an obs_sequence with randomly located columns of -observations (essentially synthetic radiosondes) that observe surface pressure -along with temperature and wind components at all model levels. ++ | Program ``column_rand`` creates an obs_sequence with randomly located columns of + | observations (essentially synthetic radiosondes) that observe surface pressure + | along with temperature and wind components at all model levels. + ++ | Program ``id_set_def_stdin`` generates an obs_sequence file that observes every + | state variable with error variance of 10000 for surface pressure and 1.0 for + | temperature and wind components. + ++ | Program ``ps_id_stdin`` generates an obs_sequence that observes every surface + | pressure variable for the default model size (30x60) with an error variance of 100. + ++ | Program ``ps_rand_local`` generates a set of randomly located surface pressure + | observations with an interactively specified error variance. It also allows the + | observations to be confined to a rectangular subdomain. + +Diagnostics +----------- -Program ``id_set_def_stdin`` generates an obs_sequence file that observes every -state variable with error variance of 10000 for surface pressure and 1.0 for -temperature and wind components. +The best method to determine the performance of an experiment in which you +assimilate data from real-world sources is to compare the ensemble estimates of +the observation to your real-world data. You can estimate the bias and error of +the ensemble mean or gauge how many of the real-world observations are actually +being assimilated. These diagnostics are known as observation-space diagnostics. +DART provides the program ``obs_diag`` and MATLAB observation space diagnostics +for you to use to quickly assess the performance of your experiment. -Program ``ps_id_stdin`` generates an obs_sequence that observes every surface -pressure variable for the default model size (30x60) with an error variance of -100. +``obs_diag`` reads the ``obs_seq.final`` files and calculates several quantities, +such as the root-mean-squared error, bias, and spread, for an arbitrary number of +regions and levels. ``obs_diag`` outputs a netCDF file called ``obs_diag_output.nc``, +which can then be used in the DART MATLAB routines located in +``DART/diagnostics/matlab/``. -Program ``ps_rand_local`` generates a set of randomly located surface pressure -observations with an interactively specified error variance. It also allows the -observations to be confined to a rectangular subdomain. +For more detail on obs_diag and the MATLAB diagnostics, see +:ref:`PROGRAM obs_diag for the threed_sphere location module ` +and :ref:`MATLAB observation space diagnostics `. Namelist -------- @@ -138,19 +187,19 @@ The following values are specified in ``model_nml``. +======================+====================+===========================================+ | current_time(4) | integer | Specifies the initial time of the Bgrid | | | | model internal clock. The four integer | -| | | values are the day, hour, minutes, and | -| | | seconds. The default version of the Bgrid | +| | | values are the day, hour, minute, and | +| | | second. The default version of the Bgrid | | | | model has neither a diurnal or seasonal | | | | cycle, so these can all be set to 0, the | | | | default value. | +----------------------+--------------------+-------------------------------------------+ | override | logical | If true, then the initial model date is | | | | taken from namelist entry current_time, | -| | | even if an atmos_model.res file is found | -| | | in directory INPUT. For most DART | -| | | applications, atmospheric restart values | -| | | are coming from DART files and no INPUT | -| | | directory is used. | +| | | even if an ``atmos_model.res`` file | +| | | is found in the directory ``INPUT``. | +| | | For most DART applications, atmospheric | +| | | restart values come from DART files and | +| | | no INPUT directory is used. | +----------------------+--------------------+-------------------------------------------+ | dt_atmos | integer | Model timestep in seconds. | +----------------------+--------------------+-------------------------------------------+ @@ -168,12 +217,12 @@ The following values are specified in ``model_nml``. | | | model advance changes the time by | | | | dt_bias. However, internally the bgrid | | | | model is moving things forward by | -| | | dt_atmos. By running perfect_model_obs | +| | | dt_atmos. By running ``perfect_model_obs``| | | | with one time step for the internal bgrid | -| | | clock (for instance dt_atmos = 3600, | -| | | dt_bias = 3600), and filter with another | -| | | (dt_atmos = 3000, and dt_bias = 3600) | -| | | model error is simulated. | +| | | clock (for instance ``dt_atmos = 3600``, | +| | | ``dt_bias = 3600``), and ``filter`` with | +| | | another (``dt_atmos = 3000``, ``dt_bias = | +| | | 3600``), model error is simulated. | +----------------------+--------------------+-------------------------------------------+ | state_variables(:,2) | character(len=129) | Strings that identify the bgrid_solo | | | | variables that should be part of the DART | @@ -184,19 +233,19 @@ The following values are specified in ``model_nml``. | template_file | character(len=256) | This is the name of the file that | | | | specifies the resolution of the variables | | | | DART uses to create the DART state | -| | | vector. If *template_file = "null"* the | -| | | *&bgrid_cold_start_nml* namelist | +| | | vector. If ``template_file = "null"`` the | +| | | ``&bgrid_cold_start_nml`` namelist | | | | variables are used to specify the | | | | resolution. The actual input filenames | -| | | for *filter* and *perfect_model_obs* come | -| | | from their respective namelists. | +| | | for ``filter`` and ``perfect_model_obs`` | +| | | come from their respective namelists. | | | | The resolutions in the file specified in | -| | | *template_file* must match the | +| | | ``template_file`` must match the | | | | resolutions of the variables in the input | | | | filenames. To start an experiment with a | -| | | new model resolution, set template_file | -| | | to "null" and set the resolutions in | -| | | bgrid_cold_start_nml. | +| | | new model resolution, set ``template_file=| +| | | "null"`` and set the resolutions in | +| | | in the ``&bgrid_cold_start_nml``. | +----------------------+--------------------+-------------------------------------------+ The following values are specified in ``bgrid_cold_start_nml``. diff --git a/models/bgrid_solo/work/filter_input.cdl.REMOVED.git-id b/models/bgrid_solo/work/filter_input.cdl.REMOVED.git-id deleted file mode 100644 index 74b187155a..0000000000 --- a/models/bgrid_solo/work/filter_input.cdl.REMOVED.git-id +++ /dev/null @@ -1 +0,0 @@ -a1aff6a5661c8a511de0142ccd3b404b27509b82 \ No newline at end of file diff --git a/models/bgrid_solo/work/workshop_setup.sh b/models/bgrid_solo/work/workshop_setup.sh deleted file mode 100755 index 730de38259..0000000000 --- a/models/bgrid_solo/work/workshop_setup.sh +++ /dev/null @@ -1,53 +0,0 @@ -#!/bin/csh -# -# DART software - Copyright UCAR. This open source software is provided -# by UCAR, "as is", without charge, subject to all terms of use at -# http://www.image.ucar.edu/DAReS/DART/DART_download -# -# -# Executes a known "perfect model" experiment using an existing -# observation sequence file (obs_seq.in) and initial conditions appropriate -# for both 'perfect_model_obs' (perfect_input.nc) and 'filter' (filter_input.nc). -# There are enough initial conditions for 80 ensemble members in filter. -# Use ens_size = 81 and it WILL bomb. Guaranteed. -# The 'input.nml' file controls all facets of this execution. -# -# 'create_obs_sequence' and 'create_fixed_network_sequence' were used to -# create the observation sequence file 'obs_seq.in' - this defines -# what/where/when we want observations. This script builds these -# programs in support of the tutorial exercises but does not RUN them. -# -# 'perfect_model_obs' results in a true_state.nc file that contains -# the true state, and obs_seq.out - a file that contains the -# synthetic "observations" that will be assimilated by 'filter'. -# -# 'filter' results in three files (at least): preassim.nc - the state -# of all ensemble members prior to the assimilation (i.e. the forecast), -# analysis.nc - the state of all ensemble members after the -# assimilation, and obs_seq.final - the ensemble members' -# estimate of what the observations should have been. -# -# Once 'perfect_model_obs' has advanced the model and harvested the -# observations for the assimilation experiment, 'filter' may be run -# over and over by simply changing the namelist parameters in input.nml. -# -# The result of each assimilation can be explored in model-space with -# matlab scripts that directly read the netCDF output, or in observation-space. -# 'obs_diag' is a program that will create observation-space diagnostics -# for any result of 'filter' and results in a couple data files that can -# be explored with yet more matlab scripts. -#---------------------------------------------------------------------- - -# Build the DART programs -echo 'runing quickbuild.sh' -./quickbuild.sh nompi - -echo 'running perfect_model_obs' -./perfect_model_obs || exit 41 - -echo 'running filter' -./filter || exit 51 - -exit 0 - -