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

Performance Testing #287

Merged
merged 46 commits into from
Sep 26, 2024
Merged
Show file tree
Hide file tree
Changes from 40 commits
Commits
Show all changes
46 commits
Select commit Hold shift + click to select a range
91ceccf
Initial steps for adding performance testing
ldowen Jul 17, 2024
9c51f73
Start integrating Adiak
ldowen Jul 18, 2024
286985e
Merge branch 'develop' into feature/add_performance_testing
ldowen Jul 18, 2024
6dcc396
Added adiak_value functions and updated caliper.config
ldowen Jul 18, 2024
9f64517
Merge branch 'develop' into feature/add_performance_testing
ldowen Jul 19, 2024
e365424
Merge with develop
ldowen Jul 30, 2024
5b5ad91
Merge branch 'develop' into feature/add_performance_testing
ldowen Aug 1, 2024
a334025
Redid spheral spack package logic, added logic to automatically initi…
ldowen Aug 7, 2024
5acd124
Updated optparse to argparse, added singleton wrapp for the caliper c…
ldowen Aug 15, 2024
b321563
Merge branch 'develop' into feature/add_performance_testing
ldowen Aug 16, 2024
60c61cd
Fixed bugs with TimerMgr singleton
ldowen Aug 16, 2024
6e42bbe
Merge branch 'develop' into feature/add_performance_testing
ldowen Aug 19, 2024
cd3f889
Added valgrind python suppression, removed & for accessing communicat…
ldowen Aug 19, 2024
6b6628c
Fixed inconsistency in Communicator for non-MPI builds and added poin…
ldowen Aug 19, 2024
d488e50
Moved MPI finalize to occur when SpheralUtilities exits (either throu…
ldowen Aug 21, 2024
229459e
Verify MPI finalize error inside communicator routine
ldowen Aug 21, 2024
5a82358
Moved ifdefs in Communicator.hh
ldowen Aug 21, 2024
03503b6
Forgot to include DBC.hh
ldowen Aug 21, 2024
da9539e
Added more checks for mpi finalize, moved communicator routines to cc…
ldowen Aug 21, 2024
92e9706
Added timer test script and changed CMake logic for making tests, add…
ldowen Aug 22, 2024
5b46839
Added warning for caliper configurations provided to incorrect builds…
ldowen Aug 22, 2024
c010fb7
Fix bug with getting caliperreader from TPL
ldowen Aug 22, 2024
b4a6e92
Fixed timer test to accomodate issue with caliperreader
ldowen Aug 22, 2024
b57bfd9
Merge branch 'develop' into feature/add_performance_testing
ldowen Aug 29, 2024
d1bb75d
Merge branch 'develop' into feature/add_performance_testing
ldowen Aug 29, 2024
cf674cd
Added more default adiak values
ldowen Sep 4, 2024
5a68c4f
Fix random visit bug
ldowen Sep 5, 2024
f024462
Changed random digits for caliper file names to be the date and time,…
ldowen Sep 5, 2024
4c21cbd
Prevent automatically adding file extensions to caliper file names
ldowen Sep 5, 2024
209ffa5
Added caliper and adiak to TPL list, changed italics to bold for defa…
ldowen Sep 5, 2024
77270fc
Documentation changes
ldowen Sep 5, 2024
5c32362
Fixed dev build exporting, improved exporting of find_package TPLs
ldowen Sep 10, 2024
3e45c23
Changed axom to be shared by default
ldowen Sep 10, 2024
92a7295
Merge branch 'develop' into feature/add_performance_testing
ldowen Sep 10, 2024
17d78ee
Update Release notes
ldowen Sep 10, 2024
60f864e
Changing axom back to static to see if that fixes the tests
ldowen Sep 11, 2024
29a11f1
Fix bug where ENABLE_SHARED was ignored, added guards for TPL exporting
ldowen Sep 11, 2024
a133ba3
Making axom always shared
ldowen Sep 11, 2024
53e3eb0
Switched back to using axom~shared+cuda or axom+shared~cuda, added gu…
ldowen Sep 11, 2024
7ba9dbd
Remove unnecessary export config lines, add logic to properly compile…
ldowen Sep 16, 2024
d1b9f5a
Remove unused cmake variables for timer tests
ldowen Sep 18, 2024
3279a71
Stop allowing blue os test to fail in CI
ldowen Sep 19, 2024
bbc1706
Added ability to specify a caliper configuration json file, remove hi…
ldowen Sep 19, 2024
6c93ae5
Updated Caliper diagnostic documentation
ldowen Sep 25, 2024
db8dd97
Fix documentation bug
ldowen Sep 25, 2024
a249a09
More document fixes
ldowen Sep 25, 2024
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
1 change: 1 addition & 0 deletions .gitmodules
Original file line number Diff line number Diff line change
Expand Up @@ -16,3 +16,4 @@
path = extern/chai
url = https://github.com/llnl/chai
branch = feature/ManagedSharedPtr
ignore = all
5 changes: 5 additions & 0 deletions RELEASE_NOTES.md
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,9 @@ Notable changes include:
* TPL builds have been split off into a separate Gitlab CI stage to help with timeouts on allocations.
* Failed ATS runs are automatically retested once in the Gitlab CI.
* Python execute command is centralized in scripts/spheralutils.py now.
* Caliper updated v2.11.
* Adiak added as TPL.
* Created singleton wrapper for cali::ConfigManger and python wrapped Caliper timer and Adiak routines.

* Build changes / improvements:
* Distributed source directory must always be built now.
Expand All @@ -23,6 +26,8 @@ Notable changes include:
* The FSISPH package is now optional (SPHERAL\_ENABLE\_FSISPH).
* The GSPH package is now optional (SPHERAL\_ENABLE\_GSPH).
* The SVPH package is now optional (SPHERAL\_ENABLE\_SVPH).
* Cleaner Spheral Spack package.
* ENABLE\_DEV\_BUILD can now export targets properly.

* Bug Fixes / improvements:
* Wrappers for MPI calls are simplified and improved.
Expand Down
38 changes: 37 additions & 1 deletion cmake/InstallTPLs.cmake
Original file line number Diff line number Diff line change
Expand Up @@ -67,9 +67,15 @@ endif()
# Find pre-compiled TPLs
#-----------------------------------------------------------------------------------

# Any targets that used find package must be added to these lists
set(SPHERAL_FP_TPLS )
set(SPHERAL_FP_DIRS )

# Use find_package to get axom (which brings in fmt) and patch fmt
find_package(axom REQUIRED NO_DEFAULT_PATH PATHS ${axom_DIR}/lib/cmake)
list(APPEND SPHERAL_BLT_DEPENDS axom )
list(APPEND SPHERAL_FP_TPLS axom)
list(APPEND SPHERAL_FP_DIRS ${axom_DIR}/lib/cmake)

# This is a hack to handle transitive issues that come
# from using object libraries with newer version of axom
Expand All @@ -82,6 +88,31 @@ foreach(_comp ${AXOM_COMPONENTS_ENABLED})
list(APPEND SPHERAL_BLT_DEPENDS ${axom_deps})
endforeach()

message("-----------------------------------------------------------------------------")
# Use find_package to get adiak
find_package(adiak REQUIRED NO_DEFAULT_PATH PATHS ${adiak_DIR}/lib/cmake/adiak)
if(adiak_FOUND)
list(APPEND SPHERAL_BLT_DEPENDS adiak::adiak)
list(APPEND SPHERAL_FP_TPLS adiak)
list(APPEND SPHERAL_FP_DIRS ${adiak_DIR})
message("Found Adiak External Package")
endif()
message("-----------------------------------------------------------------------------")
# Use find_package to get caliper
if (ENABLE_TIMER)
# Save caliper_DIR because it gets overwritten by find_package
if(NOT CONFIG_CALIPER_DIR)
# Only save if it does not exists already
set(CONFIG_CALIPER_DIR "${caliper_DIR}" CACHE PATH "Configuration Caliper directory")
endif()
find_package(caliper REQUIRED NO_DEFAULT_PATH PATHS ${caliper_DIR}/share/cmake/caliper)
if(caliper_FOUND)
list(APPEND SPHERAL_BLT_DEPENDS caliper)
list(APPEND SPHERAL_FP_TPLS caliper)
list(APPEND SPHERAL_FP_DIRS ${caliper_DIR})
message("Found Caliper External Package")
endif()
endif()
message("-----------------------------------------------------------------------------")
find_package(RAJA REQUIRED NO_DEFAULT_PATH PATHS ${raja_DIR})
if (RAJA_FOUND)
Expand All @@ -100,6 +131,8 @@ if(chai_DIR AND USE_EXTERNAL_CHAI)
if (chai_FOUND)
message("Found chai External Package.")
endif()
list(APPEND SPHERAL_FP_TPLS chai)
list(APPEND SPHERAL_FP_DIRS ${chai_DIR})
else()
message("Using chai Submodule.")
set(chai_DIR "${SPHERAL_ROOT_DIR}/extern/chai")
Expand All @@ -108,6 +141,10 @@ else()
endif()

list(APPEND SPHERAL_BLT_DEPENDS chai camp RAJA umpire)
list(APPEND SPHERAL_FP_TPLS RAJA umpire)
list(APPEND SPHERAL_FP_DIRS ${raja_DIR} ${umpire_DIR})
set_property(GLOBAL PROPERTY SPHERAL_FP_TPLS ${SPHERAL_FP_TPLS})
set_property(GLOBAL PROPERTY SPHERAL_FP_DIRS ${SPHERAL_FP_DIRS})

message("-----------------------------------------------------------------------------")

Expand All @@ -116,7 +153,6 @@ list(APPEND SPHERAL_EXTERN_LIBS boost eigen qhull silo hdf5 polytope)

blt_list_append( TO SPHERAL_EXTERN_LIBS ELEMENTS aneos IF ENABLE_ANEOS)
blt_list_append( TO SPHERAL_EXTERN_LIBS ELEMENTS opensubdiv IF ENABLE_OPENSUBDIV)
blt_list_append( TO SPHERAL_EXTERN_LIBS ELEMENTS caliper IF ENABLE_TIMER)

# Create and install target library for each external library
foreach(lib ${SPHERAL_EXTERN_LIBS})
Expand Down
6 changes: 2 additions & 4 deletions cmake/SetupSpheral.cmake
Original file line number Diff line number Diff line change
Expand Up @@ -153,7 +153,7 @@ endif()
# Build C++ tests and install tests to install directory
#-------------------------------------------------------------------------------
if (ENABLE_TESTS)
add_subdirectory(${SPHERAL_ROOT_DIR}/tests/unit/CXXTests)
add_subdirectory(${SPHERAL_ROOT_DIR}/tests/unit)

# A macro to preserve directory structure when installing files
macro(install_with_directory)
Expand Down Expand Up @@ -189,6 +189,4 @@ if (ENABLE_TESTS)
DESTINATION ${SPHERAL_TEST_INSTALL_PREFIX})
endif()

if(NOT ENABLE_DEV_BUILD)
include(${SPHERAL_ROOT_DIR}/cmake/SpheralConfig.cmake)
endif()
include(${SPHERAL_ROOT_DIR}/cmake/SpheralConfig.cmake)
35 changes: 14 additions & 21 deletions cmake/spheral/SpheralAddLibs.cmake
Original file line number Diff line number Diff line change
Expand Up @@ -46,11 +46,6 @@ function(spheral_add_obj_library package_name obj_list_name)
# Install the headers
install(FILES ${${package_name}_headers}
DESTINATION include/${package_name})

if(ENABLE_DEV_BUILD)
install(TARGETS Spheral_${package_name}
DESTINATION lib)
endif()
# Append Spheral_${package_name} to the global object list
# For example, SPHERAL_OBJ_LIBS or LLNLSPHERAL_OBJ_LIBS
set_property(GLOBAL APPEND PROPERTY ${obj_list_name} Spheral_${package_name})
Expand All @@ -71,7 +66,7 @@ endfunction()
# ----------------------
# INPUT-OUTPUT VARIABLES
# ----------------------
# package_name : REQUIRED : Desired package name
# package_name : REQUIRED : Desired package name (either CXX or LLNLCXX)
# _cxx_obj_list : REQUIRED : List of internal targets to include
# -----------------------
# OUTPUT VARIABLES TO USE - Made available implicitly after function call
Expand All @@ -85,28 +80,29 @@ function(spheral_add_cxx_library package_name _cxx_obj_list)
get_property(SPHERAL_CXX_DEPENDS GLOBAL PROPERTY SPHERAL_CXX_DEPENDS)
# For including files in submodules, currently unused
get_property(SPHERAL_SUBMOD_INCLUDES GLOBAL PROPERTY SPHERAL_SUBMOD_INCLUDES)
# Convert package name to lower-case for export target name
string(TOLOWER ${package_name} lower_case_package)
set(export_target_name spheral_${lower_case_package}-targets)

if(ENABLE_SHARED)
# Build shared spheral C++ library
blt_add_library(NAME Spheral_${package_name}
HEADERS ${${package_name}_headers}
SOURCES ${${package_name}_sources}
DEPENDS_ON ${_cxx_obj_list} ${SPHERAL_CXX_DEPENDS} ${SPHERAL_BLT_DEPENDS}
SHARED TRUE)
if(ENABLE_DEV_BUILD)
install(TARGETS ${_cxx_obj_list}
EXPORT ${export_target_name}
DESTINATION lib)
add_library(Spheral_${package_name} INTERFACE)
target_link_libraries(Spheral_${package_name} INTERFACE ${_cxx_obj_list})
else()
# Build static spheral C++ library
# Build static or shared spheral C++ library
blt_add_library(NAME Spheral_${package_name}
HEADERS ${${package_name}_headers}
SOURCES ${${package_name}_sources}
DEPENDS_ON ${_cxx_obj_list} ${SPHERAL_CXX_DEPENDS} ${SPHERAL_BLT_DEPENDS}
SHARED FALSE)
SHARED ${ENABLE_SHARED})
endif()
target_include_directories(Spheral_${package_name} SYSTEM PRIVATE ${SPHERAL_SUBMOD_INCLUDES})
if(ENABLE_CUDA)
set_target_properties(Spheral_${package_name} PROPERTIES CUDA_SEPARABLE_COMPILATION ON)
endif()


## This cleans up library targets created with object libs. It is turned off as it triggers
## a failure on Werror and pedantic builds.
#set(_properties COMPILE_DEFINITIONS LINK_LIBRARIES LINK_OPTIONS INTERFACE_LINK_OPTIONS COMPILE_OPTIONS INTERFACE_COMPILE_OPTIONS)
Expand All @@ -118,15 +114,12 @@ function(spheral_add_cxx_library package_name _cxx_obj_list)

#set_target_properties(Spheral_${package_name} PROPERTIES INTERFACE_LINK_LIBRARIES "")

# Convert package name to lower-case for export target name
string(TOLOWER ${package_name} lower_case_package)

# Install Spheral C++ target and set it as an exportable CMake target
install(TARGETS Spheral_${package_name}
DESTINATION lib
EXPORT spheral_${lower_case_package}-targets)
EXPORT ${export_target_name})
# Export Spheral target
install(EXPORT spheral_${lower_case_package}-targets DESTINATION lib/cmake)
install(EXPORT ${export_target_name} DESTINATION lib/cmake)

# Set the r-path of the C++ lib such that it is independent of the build dir when installed
set_target_properties(Spheral_${package_name} PROPERTIES INSTALL_RPATH "${CMAKE_INSTALL_PREFIX}/lib")
Expand Down
2 changes: 1 addition & 1 deletion cmake/spheral/SpheralInstallPythonFiles.cmake
jmikeowen marked this conversation as resolved.
Show resolved Hide resolved
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,7 @@ function(spheral_install_python_files)
install(FILES ${ARGV}
DESTINATION ${SPHERAL_SITE_PACKAGES_PATH}/Spheral)
install(CODE "execute_process( \
COMMAND ${PYTHON_EXE} -m compileall DESTINATION ${SPHERAL_SITE_PACKAGES_PATH}/Spheral \
COMMAND ${PYTHON_EXE} -m compileall ${SPHERAL_SITE_PACKAGES_PATH}/Spheral \
WORKING_DIRECTORY ${CMAKE_INSTALL_PREFIX})")
endif()

Expand Down
13 changes: 8 additions & 5 deletions cmake/spheral_cxx-config.cmake.in
Original file line number Diff line number Diff line change
Expand Up @@ -23,10 +23,14 @@ if(NOT SPHERAL_FOUND)
find_package(Python3 COMPONENTS Interpreter Development)
set(PYTHON_EXE ${Python3_EXECUTABLE})
endif()

if(NOT TARGET axom)
find_package(axom REQUIRED QUIET NO_DEFAULT_PATH PATHS ${axom_DIR} ${axom_DIR}/lib ${axom_DIR}/lib/cmake)
endif()
# Loop over TPLs that use find_package
set(SPHERAL_FP_TPLS "@SPHERAL_FP_TPLS@")
set(SPHERAL_FP_DIRS "@SPHERAL_FP_DIRS@")
foreach(tpl dir IN ZIP_LISTS SPHERAL_FP_TPLS SPHERAL_FP_DIRS)
if(NOT TARGET ${tpl})
find_package(${tpl} REQUIRED QUIET NO_DEFAULT_PATH PATHS ${dir})
endif()
endforeach()
if(NOT TARGET chai)
if (@USE_EXTERNAL_CHAI@)
set(SPHERAL_CHAI_DIR "@chai_DIR@/lib/cmake/chai")
Expand All @@ -47,7 +51,6 @@ if(NOT SPHERAL_FOUND)
endif()
endif()
include("${SPHERAL_CXX_INSTALL_PREFIX}/lib/cmake/spheral_cxx-targets.cmake")

set_property(TARGET Spheral_CXX
APPEND PROPERTY
INTERFACE_INCLUDE_DIRECTORIES ${SPHERAL_CXX_INCLUDE_DIRS})
Expand Down
1 change: 0 additions & 1 deletion cmake/tpl/caliper.cmake

This file was deleted.

46 changes: 24 additions & 22 deletions docs/build_guide/include/appendecies/cmake_config.rst.inc
Original file line number Diff line number Diff line change
Expand Up @@ -28,6 +28,8 @@ For just the C++ compiled Spheral a number of TPLs are required:
- Polyclipper
- Conduit
- Axom
- Adiak
- Caliper

There are also a number of libraries / python packages that are required for compiling the python bindings and executing Spheral at runtime:

Expand Down Expand Up @@ -66,58 +68,58 @@ OpenMP and MPI support is handled through BLT. Use the option flags ``-DENABLE_
CMake variables
--------------------

In this section we list the CMake variables that can be tweaked for a Spheral build. Where appropriate the options are listed, with the default value in *italics*.
In this section we list the CMake variables that can be tweaked for a Spheral build. Where appropriate the options are listed, with the default value in **bold**.

``CMAKE_BUILD_TYPE`` (Debug, *Release*, RelWithDebInfo, MinSizeRel)
``CMAKE_BUILD_TYPE`` (Debug, **Release**, RelWithDebInfo, MinSizeRel)
Choose the type of build -- for more information see the `CMake documentation <https://cmake.org/cmake/help/latest/variable/CMAKE_BUILD_TYPE.html>`_.

``CMAKE_INSTALL_PREFIX``
The top-level path for installing Spheral include files, libraries, and any Python modules or documentation.

``ENABLE_CXXONLY`` (On, *Off*)
``ENABLE_CXXONLY`` (On, **Off**)
Do not build python wrappers for Spheral.

``ENABLE_STATIC_CXXONLY`` (On, *Off*)
``ENABLE_STATIC_CXXONLY`` (On, **Off**)
Do not build python wrappers for Spheral. Build and export static library files for Spheral.

``ENABLE_SHARED`` (*On*, Off)
``ENABLE_SHARED`` (**On**, Off)
Build Spheral C++ libraries as shared libraries.

``ENABLE_DEV_BUILD`` (On, *Off*)
``ENABLE_DEV_BUILD`` (On, **Off**)
Builds separate internal C++ libraries for faster code development.

``<TPL-Name-Here>_DIR``
Directory of previously built TPL.

``ENABLE_STATIC_TPL`` (On, *Off*)
``ENABLE_STATIC_TPL`` (On, **Off**)
Link static libraries instead of shared for HDF5 and Conduit.

``ENABLE_OPENMP`` (*On*, Off)
``ENABLE_OPENMP`` (**On**, Off)
Support for OpenMP.

``ENABLE_MPI`` (*On*, Off)
``ENABLE_MPI`` (**On**, Off)
Support for MPI.

``ENABLE_1D`` (*On*, Off)
``ENABLE_1D`` (**On**, Off)
Build Spheral with 1D support.

``ENABLE_2D`` (*On*, Off)
``ENABLE_2D`` (**On**, Off)
Build Spheral with 2D support.

``ENABLE_3D`` (*On*, Off)
``ENABLE_3D`` (**On**, Off)
Build Spheral with 3D support.

``ENABLE_ANEOS`` (*On*, Off)
``ENABLE_ANEOS`` (**On**, Off)
Install the ANEOS (Analytics Equation of State) package along with the Spheral interface to it. This is a legacy equation of state frequently used for geophysical materials. See descriptions in the `iSALE <https://github.com/isale-code/M-ANEOS>`_ documentation.

``ENABLE_HELMHOLTZ`` (*On*, Off)
``ENABLE_HELMHOLTZ`` (**On**, Off)
Compile the included Helmholtz equation of state, typically used in astrophysical calculations. See a discussion `here <http://cococubed.asu.edu/code_pages/eos.shtml>`_.

``ENABLE_OPENSUBDIV`` (*On*, Off)
``ENABLE_OPENSUBDIV`` (**On**, Off)
Install the Opensubdiv library along with the Spheral interface to it. Opensubdiv is a `Pixar provided library <https://github.com/PixarAnimationStudios/OpenSubdiv>`_, which Spheral uses to implement refinement of polyhedra for some specialized problem generation capabilities.

``ENABLE_TIMER`` (*On*, Off)
Enable timer information from Spheral.
``ENABLE_TIMER`` (On, **Off**)
Enable Caliper timer information for Spheral.

``DBC_MODE`` (None, All, Pre)
Set the compile time design by contract (DBC) mode for Spheral. Design by contract statements are very useful developer tools, whereby the developer can insert tests in the code as they write it. These statements are both useful for tracking down bugs with fine-grained testing throughout the code, as well as useful documentation in the code about what sort of conditions are expected to hold.
Expand All @@ -138,23 +140,23 @@ In this section we list the CMake variables that can be tweaked for a Spheral bu

It is worth noting ``DBC_MODE=All`` is quite expensive at run time (of order 4x more), so this is not intended to be active for a release/production compilation of Spheral.

``ENABLE_WARNINGS`` (On, *Off*)
``ENABLE_WARNINGS`` (On, **Off**)
Enable compiler warnings.

``ENABLE_BOUNDCHECKING`` (On, *Off*)
``ENABLE_BOUNDCHECKING`` (On, **Off**)
If building with the Gnu compilers enable STL bound checking by passing -D_GLIBCXX_DEBUG=1 to the compiler.
Note, this is a very expensive option at runtime!

``ENABLE_NAN_EXCEPTIONS`` (On, *Off*)
``ENABLE_NAN_EXCEPTIONS`` (On, **Off**)
Raise exceptions in the C++ code when floating-point exceptions occur. Gnu compilers only.

``ENABLE_DOCS`` (On, *Off*)
``ENABLE_DOCS`` (On, **Off**)
Choose whether or not to build this documentation.

``SPHINX_EXECUTABLE``
Specify where the Sphinx executable is that should be used to build documentation. If not given, assumes the Spheral built Sphinx will be used.

``SPHINX_THEME`` (*sphinx_rtd_theme*)
``SPHINX_THEME`` (**sphinx_rtd_theme**)
Give the Sphinx theme to use when generating documentation. Default based on read the docs theme.

``SPHINX_THEME_DIR``
Expand Down
2 changes: 1 addition & 1 deletion docs/conf.py
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,7 @@
# -- Project information -----------------------------------------------------

project = 'Spheral'
copyright = '2012, LLNS'
copyright = '2024, LLNS'
author = 'J. Michael Owen'

# The short X.Y version
Expand Down
2 changes: 1 addition & 1 deletion docs/conf.py.in
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,7 @@ import sphinx_rtd_theme
# -- Project information -----------------------------------------------------

project = 'Spheral'
copyright = '2012, LLNS'
copyright = '2024, LLNS'
author = 'J. Michael Owen'

# The short X.Y version
Expand Down
Loading
Loading