Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Quickbuild mpif08 #562

Merged
merged 25 commits into from
Nov 7, 2023
Merged
Show file tree
Hide file tree
Changes from 7 commits
Commits
Show all changes
25 commits
Select commit Hold shift + click to select a range
73baddf
Create mkmf.template.nvhpc
ann-norcio Oct 5, 2023
fb07add
Adding comment about ftn (Derecho/Cray) and nvfortran (non-Cray machi…
mjs2369 Oct 9, 2023
f318a53
addind IEEE flag
hkershaw-brown Oct 23, 2023
0cbe8b2
add suggested debugging flags
hkershaw-brown Oct 23, 2023
b1ddaf2
removed loop because 1 test is sufficent to find the compiler bug #495
hkershaw-brown Sep 29, 2023
960eed1
comment - for completeness ran_twist is from numerical recipies
hkershaw-brown Sep 29, 2023
ec0a431
option for mpif08
hkershaw-brown Oct 23, 2023
89621bc
mpif08 for quickbuild.sh for models
hkershaw-brown Oct 23, 2023
851978d
add mpi to the list of optional 1st argumements
hkershaw-brown Oct 23, 2023
2ff7237
fix: nompi needs mpif08 modules removed from list of source files
hkershaw-brown Oct 23, 2023
fa3cf2d
doc fix: rename assim_mod_mod docs to match the module
hkershaw-brown Oct 23, 2023
c78fa71
fix: sync filter_mod.dopplerfold with filter_mod
hkershaw-brown Oct 26, 2023
0cd7030
fix: converters need mpif08 removed from list of source files
hkershaw-brown Nov 6, 2023
d5b3779
typo in usage for quickbuild.sh
hkershaw-brown Nov 6, 2023
4fb221f
doc: added quickbuild.sh usage to compiling dart
hkershaw-brown Nov 6, 2023
0e92728
Fixes for remaining documentation warnings in #546
c-merchant Nov 6, 2023
7810c6e
fix: usage for obs converter quickbuild.sh
hkershaw-brown Nov 6, 2023
3af2899
fix: usage message mpi/nompi/mpif08 in script and docs
hkershaw-brown Nov 6, 2023
e39aa8f
doc: add converter quickbuild usage
hkershaw-brown Nov 7, 2023
d64061d
bump version and changelog for release
hkershaw-brown Nov 7, 2023
b324e02
Merge pull request #573 from c-merchant/doc_notes
hkershaw-brown Nov 7, 2023
45013ee
Merge pull request #561 from NCAR/random-test-no-loop
hkershaw-brown Nov 7, 2023
251ffb1
Merge pull request #557 from ann-norcio/add-mkmf.template.nvhpc
hkershaw-brown Nov 7, 2023
dcf9ad0
Merge pull request #564 from NCAR/doc-rename
hkershaw-brown Nov 7, 2023
40ad949
Merge pull request #567 from NCAR/sync-dopplerfold
hkershaw-brown Nov 7, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion assimilation_code/modules/utilities/fixsystem
Original file line number Diff line number Diff line change
Expand Up @@ -39,7 +39,7 @@
#

# default file list, and both marker strings must exist in these files
export FLIST="mpi_utilities_mod.f90 null_mpi_utilities_mod.f90"
export FLIST="mpi_utilities_mod.f90 null_mpi_utilities_mod.f90 mpif08_utilities_mod.f90 "
export STRINGS_REQUIRED=1

# compiler name required. additional filenames optional.
Expand Down
2,050 changes: 2,050 additions & 0 deletions assimilation_code/modules/utilities/mpif08_utilities_mod.f90

Large diffs are not rendered by default.

194 changes: 194 additions & 0 deletions assimilation_code/modules/utilities/no_cray_winf08_mod.f90
Original file line number Diff line number Diff line change
@@ -0,0 +1,194 @@
! 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

!> Window without cray pointer. Should you point the window at contigous memory?
module window_mod

!> \defgroup window window_mod
!> @{
use mpi_utilities_mod, only : datasize, my_task_id, get_dart_mpi_comm
use types_mod, only : r8, i8
use ensemble_manager_mod, only : ensemble_type, map_pe_to_task, get_var_owner_index, &
copies_in_window, init_ensemble_manager, &
get_allow_transpose, end_ensemble_manager, &
set_num_extra_copies, all_copies_to_all_vars, &
all_vars_to_all_copies

use mpi_f08

implicit none

private
public :: create_mean_window, create_state_window, free_mean_window, &
free_state_window, data_count, mean_win, state_win, current_win, &
mean_ens_handle, NO_WINDOW, MEAN_WINDOW, STATE_WINDOW

! mpi window handles
type(MPI_Win) :: state_win !< window for the forward operator
type(MPI_Win) :: mean_win !< window for the mean
integer :: current_win !< keep track of current window, start out assuming an invalid window

! parameters for keeping track of which window is open
!>@todo should this be in the window_mod? you will have to change in both cray
!> and non cray versions
integer, parameter :: NO_WINDOW = -1
integer, parameter :: MEAN_WINDOW = 0
integer, parameter :: STATE_WINDOW = 2

integer :: data_count !! number of copies in the window
integer(KIND=MPI_ADDRESS_KIND) :: window_size
logical :: use_distributed_mean = .false. ! initialize to false

! Global memory to stick the mpi window to.
! Need a simply contiguous piece of memory to pass to mpi_win_create
! Openmpi 1.10.0 will not compile with ifort 16 if
! you create a window with a 2d array.
real(r8), allocatable :: contiguous_fwd(:)
real(r8), allocatable :: mean_1d(:)

type(ensemble_type) :: mean_ens_handle

contains

!-------------------------------------------------------------
!> For the non-distributed case this is simply a transpose
!> For the distributed case memory is allocated in this module
!> then an mpi window is attached to this memory.
subroutine create_state_window(state_ens_handle, fwd_op_ens_handle, qc_ens_handle)

type(ensemble_type), intent(inout) :: state_ens_handle
type(ensemble_type), intent(inout), optional :: fwd_op_ens_handle
type(ensemble_type), intent(inout), optional :: qc_ens_handle

integer :: ierr
integer :: bytesize !< size in bytes of each element in the window
integer :: my_num_vars !< my number of vars

! Find out how many copies to put in the window
! copies_in_window is not necessarily equal to ens_handle%num_copies
data_count = copies_in_window(state_ens_handle)

if (get_allow_transpose(state_ens_handle)) then
call all_copies_to_all_vars(state_ens_handle)
if (present(fwd_op_ens_handle)) then
call all_copies_to_all_vars(fwd_op_ens_handle)
endif
if (present(qc_ens_handle)) then
call all_copies_to_all_vars(qc_ens_handle)
endif
else
! find how many variables I have
my_num_vars = state_ens_handle%my_num_vars

call mpi_type_size(datasize, bytesize, ierr)
window_size = my_num_vars*data_count*bytesize

allocate(contiguous_fwd(data_count*my_num_vars))
contiguous_fwd = reshape(state_ens_handle%copies(1:data_count, :), (/my_num_vars*data_count/))

! Expose local memory to RMA operation by other processes in a communicator.
call mpi_win_create(contiguous_fwd, window_size, bytesize, MPI_INFO_NULL, get_dart_mpi_comm(), state_win, ierr)
endif

! Set the current window to the state window
current_win = STATE_WINDOW

data_count = copies_in_window(state_ens_handle)

end subroutine create_state_window

!-------------------------------------------------------------
!> Using a mean ensemble handle.
!>
subroutine create_mean_window(state_ens_handle, mean_copy, distribute_mean)

type(ensemble_type), intent(in) :: state_ens_handle
integer, intent(in) :: mean_copy
logical, intent(in) :: distribute_mean

integer :: ierr
integer :: bytesize
integer :: my_num_vars !< number of elements a task owns

! create an ensemble handle of just the mean copy.
use_distributed_mean = distribute_mean

if (use_distributed_mean) then
call init_ensemble_manager(mean_ens_handle, 1, state_ens_handle%num_vars) ! distributed ensemble
call set_num_extra_copies(mean_ens_handle, 0)
mean_ens_handle%copies(1,:) = state_ens_handle%copies(mean_copy, :)
allocate(mean_1d(state_ens_handle%my_num_vars))
mean_1d(:) = mean_ens_handle%copies(1,:)

! find out how many variables I have
my_num_vars = mean_ens_handle%my_num_vars
call mpi_type_size(datasize, bytesize, ierr)
window_size = my_num_vars*bytesize

! Need a simply contiguous piece of memory to pass to mpi_win_create
! Expose local memory to RMA operation by other processes in a communicator.
call mpi_win_create(mean_1d, window_size, bytesize, MPI_INFO_NULL, get_dart_mpi_comm(), mean_win, ierr)
else
call init_ensemble_manager(mean_ens_handle, 1, state_ens_handle%num_vars, transpose_type_in = 3)
call set_num_extra_copies(mean_ens_handle, 0)
mean_ens_handle%copies(1,:) = state_ens_handle%copies(mean_copy, :)
call all_copies_to_all_vars(mean_ens_handle) ! this is a transpose-duplicate
endif

! grabbing mean directly, no windows are being used
current_win = MEAN_WINDOW

data_count = copies_in_window(mean_ens_handle) ! One.

end subroutine create_mean_window

!-------------------------------------------------------------
!> End epoch of state access.
!> Need to transpose qc and fwd operator back to copy complete
subroutine free_state_window(state_ens_handle, fwd_op_ens_handle, qc_ens_handle)

type(ensemble_type), intent(inout) :: state_ens_handle
type(ensemble_type), intent(inout), optional :: fwd_op_ens_handle
type(ensemble_type), intent(inout), optional :: qc_ens_handle

integer :: ierr

if(get_allow_transpose(state_ens_handle)) then ! the forward operators were done var complete
!transpose back if present
if (present(fwd_op_ens_handle)) &
call all_vars_to_all_copies(fwd_op_ens_handle)
if (present(qc_ens_handle)) &
call all_vars_to_all_copies(qc_ens_handle)
else
! close mpi window
call mpi_win_free(state_win, ierr)
deallocate(contiguous_fwd)
endif

current_win = NO_WINDOW

end subroutine free_state_window

!---------------------------------------------------------
!> Free the mpi window
subroutine free_mean_window()

integer :: ierr

if(get_allow_transpose(mean_ens_handle)) then
call end_ensemble_manager(mean_ens_handle)
else
call mpi_win_free(mean_win, ierr)
deallocate(mean_1d)
call end_ensemble_manager(mean_ens_handle)
endif

current_win = NO_WINDOW

end subroutine free_mean_window

!-------------------------------------------------------------
!> @}
end module window_mod

Original file line number Diff line number Diff line change
Expand Up @@ -640,7 +640,7 @@ subroutine get_from_fwd(owner, window, mindex, num_rows, x)
integer, intent(in) :: window ! window object
integer, intent(in) :: mindex ! index in the tasks memory
integer, intent(in) :: num_rows ! number of rows in the window
real(r8), intent(out) :: x(:) ! result
real(r8), intent(out) :: x(num_rows) ! result

call error_handler(E_ERR,'get_from_fwd', 'cannot be used in serial mode', source)

Expand Down
6 changes: 6 additions & 0 deletions build_templates/buildconvfunctions.sh
Original file line number Diff line number Diff line change
Expand Up @@ -120,15 +120,19 @@ local obserrsrc=$DART/observations/obs_converters/obs_error/$OBS_ERROR"_obs_err_

# remove null/mpi from list
local mpi="$DART"/assimilation_code/modules/utilities/mpi_utilities_mod.f90
local mpif08="$DART"/assimilation_code/modules/utilities/mpif08_utilities_mod.f90
local nullmpi="$DART"/assimilation_code/modules/utilities/null_mpi_utilities_mod.f90
local nullwin="$DART"/assimilation_code/modules/utilities/null_win_mod.f90
local craywin="$DART"/assimilation_code/modules/utilities/cray_win_mod.f90
local nocraywin="$DART"/assimilation_code/modules/utilities/no_cray_win_mod.f90
local no_cray_winf08="$DART"/assimilation_code/modules/utilities/no_cray_winf08_mod.f90

if [ "$mpisrc" == "mpi" ]; then

core=${core//$nullmpi/}
core=${core//$nullwin/}
core=${core//$mpif08/}
core=${core//$no_cray_winf08/}
if [ "$windowsrc" == "craywin" ]; then
core=${core//$nocraywin/}
else #nocraywin
Expand All @@ -137,7 +141,9 @@ if [ "$mpisrc" == "mpi" ]; then
else #nompi

core=${core//$mpi/}
core=${core//$mpif08/}
core=${core//$nocraywin/}
core=${core//$no_cray_winf08/}
core=${core//$craywin/}
fi

Expand Down
44 changes: 38 additions & 6 deletions build_templates/buildfunctions.sh
Original file line number Diff line number Diff line change
Expand Up @@ -52,16 +52,21 @@ function print_usage() {
echo " quickbuild.sh clean : clean the build"
echo " quickbuild.sh help : print help message"
echo " "
echo " quickbuild.sh [nompi] [program] : optional arguments "
echo " [nompi] build without mpi"
echo " [program] build a single program"
echo " quickbuild.sh [nompi/nompi/mpif08] [program] : optional arguments "
echo " [mpi] build with mpi (default)"
echo " [nompi] build without mpi"
echo " [mpif08] build with mpi using mpi_f08"
echo " [program] build a single program"
echo " "
echo " Example 1. Build filter without mpi:"
echo " quickbuild.sh nompi filter"
echo " "
echo " Example 2. Build perfect_model_obs with mpi"
echo " quickbuild.sh perfect_model_obs"
echo " "
echo " Example 3. Build perfect_model_obs with mpi using the mpi_f08 bindings"
echo " quickbuild.sh mpif08 perfect_model_obs"
echo " "
exit
}

Expand Down Expand Up @@ -96,12 +101,12 @@ if [ $# -gt 2 ]; then
print_usage
fi

# Default to build with mpi
# Default to build with mpi (non f08 version)
mpisrc=mpi
windowsrc=no_cray_win
m="-w" # mkmf wrapper arg

# if the first argument is help, nompi, clean
# if the first argument is help, nompi, mpi, mpif08, clean
case $1 in
help)
print_usage
Expand All @@ -114,6 +119,18 @@ case $1 in
shift 1
;;

mpi)
mpisrc="mpi"
windowsrc="no_cray_win"
shift 1
;;

mpif08)
mpisrc="mpif08"
windowsrc="no_cray_winf08"
shift 1
;;

clean)
cleanup
exit
Expand Down Expand Up @@ -146,24 +163,39 @@ local misc="$DART/models/utilities/ \

# remove null/mpi from list
local mpi="$DART"/assimilation_code/modules/utilities/mpi_utilities_mod.f90
local mpif08="$DART"/assimilation_code/modules/utilities/mpif08_utilities_mod.f90
local nullmpi="$DART"/assimilation_code/modules/utilities/null_mpi_utilities_mod.f90
local nullwin="$DART"/assimilation_code/modules/utilities/null_win_mod.f90
local craywin="$DART"/assimilation_code/modules/utilities/cray_win_mod.f90
local nocraywin="$DART"/assimilation_code/modules/utilities/no_cray_win_mod.f90
local no_cray_winf08="$DART"/assimilation_code/modules/utilities/no_cray_winf08_mod.f90

if [ "$mpisrc" == "mpi" ]; then

core=${core//$nullmpi/}
core=${core//$nullwin/}
core=${core//$mpif08/}
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

this looks backwards to me - is it just the labels? mpi includes the nullmpi version, and below the #nompi version includes the mpi modules?

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

It does look backwards with the // at the beginning, but if you believe me:

core=${core//$nullmpi/}

replace all matches (// ) of$nullmpi from $core with nothing ('/ ')

so for mpi, remove null, nullwin, mpif08, mpif08, no_cray_winf08

core=${core//$no_cray_winf08/}
if [ "$windowsrc" == "craywin" ]; then
core=${core//$nocraywin/}
else #nocraywin
core=${core//$craywin/}
fi
else #nompi

elif [ "$mpisrc" == "mpif08" ]; then

core=${core//$nullmpi/}
core=${core//$nullwin/}
core=${core//$mpi/}
core=${core//$craywin/}
core=${core//$nocraywin/}

else #nompi

core=${core//$mpi/}
core=${core//$mpif08/}
core=${core//$nocraywin/}
core=${core//$no_cray_winf08/}
core=${core//$craywin/}
fi

Expand Down
22 changes: 22 additions & 0 deletions guide/compiling-dart.rst
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,28 @@ To build DART executables you will need to
For example, if you want to build DART for the lorenz_63 model, ``cd DART/models/lorenz_63/work``
#. Build the DART executables with ``./quickbuild.sh``

.. code-block:: text

Usage:
quickbuild.sh : build everything
quickbuild.sh clean : clean the build
quickbuild.sh help : print help message

quickbuild.sh [nompi/nompi/mpif08] [program] : optional arguments
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
quickbuild.sh [nompi/nompi/mpif08] [program] : optional arguments
quickbuild.sh [mpi/nompi/mpif08] [program] : optional arguments

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

fixed in 3af2899

[mpi] build with mpi (default)
[nompi] build without mpi
[mpif08] build with mpi using mpi_f08
[program] build a single program

Example 1. Build filter without mpi:
quickbuild.sh nompi filter

Example 2. Build perfect_model_obs with mpi
quickbuild.sh perfect_model_obs

Example 3. Build perfect_model_obs with mpi using the mpi_f08 bindings
quickbuild.sh mpif08 perfect_model_obs


For more detail on how quickbuild.sh works see :ref:`DART build system`.

Expand Down
2 changes: 2 additions & 0 deletions index.rst
Original file line number Diff line number Diff line change
Expand Up @@ -121,6 +121,8 @@ If you are planning to run one of the larger models and want to use the Lorenz
63 model as a test, run ``./quickbuild.sh``. It will build filter and any
other MPI-capable executables with MPI.

``./quickbuild.sh help`` will print out the quickbuild.sh usage.

.. important::

The ``mpif90`` command you use must have been built with the same version of
Expand Down