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

Add fv3-jedi and its dependencies (SkyLab 8 version) #395

Open
wants to merge 10 commits into
base: spack-stack-dev
Choose a base branch
from

Conversation

rhoneyager-tomorrow
Copy link

Description

The previous PR (#306) has been around for a while. I have updated it for the new SkyLab v7 release.

This provides the same as before, with the addition of mom6 and soca packages.

Errata

I've excluded updates/additions of mpas-model and mpas-jedi from this PR. The mpas package on Spack is entirely incompatible with the JCSDA fork. CMake packaging logic vs a custom Makefile. I tested production of a CMake-ified version mpas-model package, but there is a bug in the CMake package export logic in the JCSDA fork, and this prevents use with mpas-jedi.

Checklist

  • I have performed a self-review of my own code
  • I have made corresponding changes to the documentation
  • I have run the unit tests before creating the PR

@climbfuji
Copy link
Collaborator

@rhoneyager-tomorrow This replaces #306, correct?

@climbfuji climbfuji self-requested a review January 25, 2024 15:43
@climbfuji climbfuji self-assigned this Jan 25, 2024
@climbfuji climbfuji added the INFRA JEDI Infrastructure label Jan 25, 2024
@rhoneyager-tomorrow
Copy link
Author

Yes. I can close the old version.

@climbfuji
Copy link
Collaborator

@rhoneyager-tomorrow Let's see if we can get this PR merged/resolved. My preference would be to apply all the patches that you submitted here to the Skylab v8 release and then do away with anything prior to that in the spack PR. I would also prefer to pick apart this PR and add/update packages individually. For packages that are also in spack mainline, I would prefer submitting the updates to the upstream repo first and then bring them down to our fork.

Other notes:

  • Hopefully we don't need to maintain our GFDL_atmos_cubed_sphere fork for much longer and can just use the FV3 dycore code from GFDL directly (without the ecbuild stuff on top).
  • The spack-stack package "spack repo" that used to be var/spack/repos/jcsda_emc/...is now part of the spack-stack GitHub repository in subdirectoryspack-ext`

I can assist with or take care of some or most of this work, but hopefully we can split the work somewhat. Thoughts?

@climbfuji
Copy link
Collaborator

@rhoneyager-tomorrow I am going to submit this to femps (note that I removed the HINTS since the spack-package adds the external dependency on ecbuild:

diff --git a/CMakeLists.txt b/CMakeLists.txt
index 6b2e041..9f570cb 100644
--- a/CMakeLists.txt
+++ b/CMakeLists.txt
@@ -4,6 +4,8 @@

 cmake_minimum_required( VERSION 3.3.2 FATAL_ERROR )

+find_package( ecbuild 3.6 REQUIRED )
+
 project( femps VERSION 1.2.0 LANGUAGES Fortran )

 set( CMAKE_MODULE_PATH ${CMAKE_CURRENT_SOURCE_DIR}/cmake;${CMAKE_MODULE_PATH})
diff --git a/src/femps/CMakeLists.txt b/src/femps/CMakeLists.txt
index f7c2e65..3852a11 100644
--- a/src/femps/CMakeLists.txt
+++ b/src/femps/CMakeLists.txt
@@ -25,3 +25,11 @@ ecbuild_add_library( TARGET          femps

 target_include_directories( femps INTERFACE $<BUILD_INTERFACE:${CMAKE_Fortran_MODULE_DIRECTORY}>
                                             $<INSTALL_INTERFACE:${CMAKE_INSTALL_INCLUDEDIR}>)
+
+# Fortran module output directory for build and install interfaces
+set( MODULE_DIR module/${PROJECT_NAME}/${CMAKE_Fortran_COMPILER_ID}/${CMAKE_Fortran_COMPILER_VERSION} )
+set_target_properties( ${PROJECT_NAME} PROPERTIES Fortran_MODULE_DIRECTORY ${CMAKE_BINARY_DIR}/${MODULE_DIR} )
+install( DIRECTORY ${CMAKE_BINARY_DIR}/${MODULE_DIR}/ DESTINATION ${MODULE_DIR} )
+target_include_directories( femps INTERFACE
+                            $<BUILD_INTERFACE:${CMAKE_BINARY_DIR}/${MODULE_DIR}>
+                            $<INSTALL_INTERFACE:${MODULE_DIR}> )

Does that look ok for you?

@climbfuji
Copy link
Collaborator

Same for fv3-jedi-linearmodel:

diff --git a/CMakeLists.txt b/CMakeLists.txt
index ffa8887..1d4f7f1 100644
--- a/CMakeLists.txt
+++ b/CMakeLists.txt
@@ -15,6 +15,8 @@ set( CMAKE_MODULE_PATH ${CMAKE_CURRENT_SOURCE_DIR}/cmake;${CMAKE_MODULE_PATH} )

 set( CMAKE_DIRECTORY_LABELS "fv3-jedi-lm" )

+find_package( ecbuild 3.6 REQUIRED )
+
 set( ECBUILD_DEFAULT_BUILD_TYPE Release )
 set( ENABLE_OS_TESTS           OFF CACHE BOOL "Disable OS tests" FORCE )
 set( ENABLE_LARGE_FILE_SUPPORT OFF CACHE BOOL "Disable testing of large file support" FORCE )
diff --git a/src/CMakeLists.txt b/src/CMakeLists.txt
index 2d320ef..f4e4406 100644
--- a/src/CMakeLists.txt
+++ b/src/CMakeLists.txt
@@ -40,3 +40,11 @@ endif()
 if(CMAKE_Fortran_COMPILER_ID MATCHES GNU AND CMAKE_Fortran_COMPILER_VERSION VERSION_GREATER_EQUAL 10)
     target_compile_options(fv3jedilm PRIVATE $<$<COMPILE_LANGUAGE:Fortran>:-fallow-argument-mismatch>)
 endif()
+
+# Fortran module output directory for build and install interfaces
+set( MODULE_DIR module/${PROJECT_NAME}/${CMAKE_Fortran_COMPILER_ID}/${CMAKE_Fortran_COMPILER_VERSION} )
+set_target_properties( ${PROJECT_NAME} PROPERTIES Fortran_MODULE_DIRECTORY ${CMAKE_BINARY_DIR}/${MODULE_DIR} )
+install( DIRECTORY ${CMAKE_BINARY_DIR}/${MODULE_DIR}/ DESTINATION ${MODULE_DIR} )
+target_include_directories( fv3jedilm INTERFACE
+                            $<BUILD_INTERFACE:${CMAKE_BINARY_DIR}/${MODULE_DIR}>
+                            $<INSTALL_INTERFACE:${MODULE_DIR}> )

variant("mpi", default=True, description="Support for MPI distributed parallelism")
variant("openmp", default=True, description="Build with OpenMP support")

conflicts("forecast_model=GEOS", msg="FV3-JEDI-LINEARMODEL: GEOS to be implemented.")
Copy link
Collaborator

Choose a reason for hiding this comment

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

I think we are using the current fv3-jedi-linearmodel with GEOS and UFS - @shlyaeva can you comment on this?

Copy link
Author

@rhoneyager-tomorrow rhoneyager-tomorrow Mar 11, 2024

Choose a reason for hiding this comment

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

You're using both, but at time of writing this PR GEOS wasn't fully buildable in Spack. Likewise, the ufs-bundle depended on JCSDA-internal, so I didn't have much insight there.

Copy link
Collaborator

Choose a reason for hiding this comment

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

I think we can merge it as-is now, and update later as needed

depends_on("ecbuild", type=("build"))
depends_on("ecbuild@3.3.2:", type=("build"), when="@3.0.7:")

version("3.0.7", commit="1a02ebaf6f7a4e9f2c2d2dd973fb050e697bcc74")
Copy link
Collaborator

Choose a reason for hiding this comment

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

Note the non-standard notation of the tag. In the repo, it's v3.07

+++ b/CMakeLists.txt
@@ -42,7 +42,7 @@ find_package( atlas 0.33.0 REQUIRED COMPONENTS OMP_Fortran )
if( ENABLE_MKL )
find_package( MKL )
Copy link
Collaborator

Choose a reason for hiding this comment

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

In fact, this should rather be

if( ENABLE_MKL )
    find_package( MKL REQUIRED )

(at least that is what we decided at JCSDA - if you request a feature then it is an error if it is not available)

Copy link
Collaborator

@climbfuji climbfuji Mar 12, 2024

Choose a reason for hiding this comment

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

Actually, we already have the change that you made in develop, and your version makes more sense than what I was thinking initially. That's because it's easier going to use Intel MKL or LAPACK, but if both are missing it will abort. I am going to revert that comment. I will make it a hard requirement if someone asks for MKL.

Copy link
Collaborator

Choose a reason for hiding this comment

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

My idea doesn't work, fixing the underlying problem requires changes across several repositories.

@rhoneyager-tomorrow
Copy link
Author

@rhoneyager-tomorrow Let's see if we can get this PR merged/resolved. My preference would be to apply all the patches that you submitted here to the Skylab v8 release and then do away with anything prior to that in the spack PR. I would also prefer to pick apart this PR and add/update packages individually. For packages that are also in spack mainline, I would prefer submitting the updates to the upstream repo first and then bring them down to our fork.

SkyLab 8 isn't released yet, but I expect that it will take some time for all the patches to be applied, so I'm quite fine with everything that you propose.

Other notes:

  • Hopefully we don't need to maintain our GFDL_atmos_cubed_sphere fork for much longer and can just use the FV3 dycore code from GFDL directly (without the ecbuild stuff on top).

Great news! Hopefully you can do the same with mpas eventually.

  • The spack-stack package "spack repo" that used to be var/spack/repos/jcsda_emc/...is now part of the spack-stack GitHub repository in subdirectoryspack-ext`

I can assist with or take care of some or most of this work, but hopefully we can split the work somewhat. Thoughts?

Splitting works for me. Let me know once you finish reviewing.

@climbfuji
Copy link
Collaborator

I created the PRs for femps and fv3-jedi-linearmodel so far based on what I posted above

@climbfuji
Copy link
Collaborator

Regarding the ecmwf-atlas update: version 0.36.0 is already in spack develop, and I just opened spack#43133 to add the missing ecbuild@3.4: dependency. Once that's merged, I can bring both updates down to our fork.

@climbfuji
Copy link
Collaborator

@rhoneyager-tomorrow We merged the femps and fv3-jedi-linearmodel build system bug fixes. Do you want to check the public develop branches? That will be in the Skylab v8 releases.

@@ -20,6 +20,7 @@ class EcmwfAtlas(CMakePackage):

version("master", branch="master")
version("develop", branch="develop")
version("0.36.0", sha256="39bf748aa7b22df80b9791fbb6b4351ed9a9f85587b58fc3225314278a2a68f8")
Copy link
Collaborator

Choose a reason for hiding this comment

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

Changes to this file will no longer be needed. We merged the missing ecbuild@3.4: dependency upstream (spack#43133); spack develop already had 0.36.0. We'll bring both updates to our spack fork shortly.

depends_on("netcdf-c")
depends_on("netcdf-fortran")

# find_package(ecbuild REQUIRED) is needed when using ecbuild.
Copy link
Collaborator

Choose a reason for hiding this comment

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

Patches should no longer be required if we target sklyab v8

res = [self.define_from_variant("FV3_FORECAST_MODEL", "forecast_model")]
return res

# find_package(ecbuild REQUIRED) is needed when using ecbuild.
Copy link
Collaborator

Choose a reason for hiding this comment

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

Patches should no longer be required if we target sklyab v8

@@ -0,0 +1,11 @@
--- a/CMakeLists.txt
Copy link
Collaborator

Choose a reason for hiding this comment

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

No longer required for Skylab v8 because of JCSDA/GFDL_atmos_cubed_sphere#3

@climbfuji
Copy link
Collaborator

climbfuji commented Mar 14, 2024

@rhoneyager-tomorrow Here is an update on the PR: I've merged the following patches (w/ slight modifications into the develop code, to be released in Skylab v8 next month):

  • var/spack/repos/jcsda-emc/packages/GFDL_atmos_cubed_sphere/CMakeLists.txt.patch
  • var/spack/repos/jcsda-emc/packages/femps/CMakeLists.txt.patch
  • var/spack/repos/jcsda-emc/packages/femps/src.femps.CMakeLists.txt.patch
  • var/spack/repos/jcsda-emc/packages/fv3-jedi-linearmodel/CMakeLists.txt.patch
  • var/spack/repos/jcsda-emc/packages/fv3-jedi-linearmodel/src.CMakeLists.txt.patch
  • var/spack/repos/jcsda-emc/packages/fv3-jedi/CMakeLists.txt.16.patch
  • var/spack/repos/jcsda-emc/packages/fv3-jedi/CMakeLists.txt.18.patch
  • var/spack/repos/jcsda-emc/packages/fv3-jedi/cmake.fv3jedi_extra_macros.cmake.patch
  • var/spack/repos/jcsda-emc/packages/fv3-jedi/test.CMakeLists.txt.patch
  • var/spack/repos/jcsda-emc/packages/saber/CMakeLists.txt.patch
  • var/spack/repos/jcsda-emc/packages/saber/quench.src.Fields.cc.patch
  • var/spack/repos/jcsda-emc/packages/saber/saber-import.cmake.in.patch

I also updated the following package recipes in our spack fork:

  • var/spack/repos/builtin/packages/ecmwf-atlas/package.py (and synced it with spack develop)

What needs to remain in this PR (but updated to only cover the Skylab v8 versions):

  • var/spack/repos/builtin/packages/crtm/package.py
  • var/spack/repos/jcsda-emc/packages/GFDL_atmos_cubed_sphere/package.py
  • var/spack/repos/jcsda-emc/packages/femps/package.py
  • var/spack/repos/jcsda-emc/packages/fv3-jedi-linearmodel/CMakeLists.txt.patch
  • var/spack/repos/jcsda-emc/packages/fv3-jedi/package.py
  • var/spack/repos/jcsda-emc/packages/gsw/package.py (but note that different tag name)
  • var/spack/repos/jcsda-emc/packages/ioda/package.py
  • var/spack/repos/jcsda-emc/packages/mom6/package.py
  • var/spack/repos/jcsda-emc/packages/oops/package.py
  • var/spack/repos/jcsda-emc/packages/saber/package.py
  • var/spack/repos/jcsda-emc/packages/soca/package.py
  • var/spack/repos/jcsda-emc/packages/ufo/package.py
  • var/spack/repos/jcsda-emc/packages/vader/package.py

@climbfuji climbfuji changed the title Add fv3-jedi and its dependencies (SkyLab 7 version) Add fv3-jedi and its dependencies (SkyLab 8 version) Apr 12, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
INFRA JEDI Infrastructure
Projects
Development

Successfully merging this pull request may close these issues.

4 participants