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

Bring Feature/ufo geovals up to date. #798

Merged
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
122 commits
Select commit Hold shift + click to select a range
e55a937
Regression test updates: global_4dvar bug fix, oom fix, enhance erro…
RussTreadon-NOAA Feb 11, 2023
8857995
GitHub Issue NOAA-EMC/GSI#468 Enhancements to SDL and VDL for simulta…
Wangy1111 Feb 13, 2023
df010e4
Bugfix in EnKF assim of conventional q obs (#545)
ClaraDraper-NOAA Mar 2, 2023
723a034
Update Jet support (#537)
DavidHuber-NOAA Mar 9, 2023
89c4711
gfsda.v16 merge with develop (#526)
emilyhcliu Mar 14, 2023
31b8b29
remove and update non crtm/2.4.0 references (#551)
RussTreadon-NOAA Mar 16, 2023
89ca542
GitHub Issue NOAA-EMC/GSI#538 Add options to tune weights of mixed en…
shoyokota Mar 17, 2023
4afe6ed
Add dDZ for EnKF (#536)
chunhuazhou Mar 24, 2023
113e307
Use prod ncio and ncdiag on wcoss2 (#554)
RussTreadon-NOAA Mar 28, 2023
14ae595
GitHub Issue NOAA-EMC/GSI#539 Add options to tune cross-scale/variabl…
shoyokota Apr 3, 2023
1661c15
Fix write_incr (#559)
jderber-NOAA Apr 14, 2023
48ea34a
Optimize GSI (#527)
jderber-NOAA May 9, 2023
726cc8d
Enhancement to handle hydrometeors in the EnKF I/O interface (#499)
emilyhcliu May 19, 2023
ac1a8cb
Issue with global mean weight for multiscale ensemble runs for ig > 1…
jderber-NOAA May 30, 2023
d766977
GitHub Issue NOAA-EMC/GSI#540 Modify to assimilate radar reflectivity…
shoyokota Jun 1, 2023
57ddc31
Initial changes for GFS v17 soil moisture and temperature analysis (…
ClaraDraper-NOAA Jun 5, 2023
8735959
update fix submodule to bring in gfs.v16.3.7 changes (#581)
RussTreadon-NOAA Jun 6, 2023
00cac54
Feature/enkf q2 (#568)
TingLei-daprediction Jun 27, 2023
333ae16
Zero increments for precipitation hydrometeors are written as missing…
emilyhcliu Jun 28, 2023
accb07e
Bugfix for pseudo_RH option (#602)
ClaraDraper-NOAA Aug 7, 2023
9e5aa09
changes for reanalysis runs (#591)
jack-woollen Aug 8, 2023
be4a3d9
Error in processing VAD winds. (#617)
jderber-NOAA Sep 1, 2023
d7ac706
Gsi fed (#590)
daviddowellNOAA Sep 8, 2023
a6515bd
add missing jacobian arrays to netcdf ozone diagnostic file (#618) (#…
RussTreadon-NOAA Sep 12, 2023
c46f590
Update intel compile to Intel2022 (#571)
hu5970 Sep 12, 2023
008c63c
update fix submodule hash to include gfs.v16.3.9 updates (#621)
RussTreadon-NOAA Sep 14, 2023
d84a18f
Bring in HAFSv1 Related Changes (#608)
JingCheng-NOAA Sep 20, 2023
aa656c6
fix for zero total ozone pressure in EnKF (issue #625) (#626)
jswhit Sep 22, 2023
2f4e7fe
Optimize the reading of ensembles and setup for global multiscale run…
jderber-NOAA Sep 22, 2023
ca19008
Intel 2022 updates (#629)
RussTreadon-NOAA Sep 25, 2023
728d006
Adding code to analyze the siginificant wave heigh in GSI 3D Analysis…
GangZhao-NOAA Sep 29, 2023
ba5a2ca
Refine PM2.5 DA for the RRFS_SD model (#609)
hongli-wang Sep 29, 2023
c56d7bc
GitHub Issue NOAA-EMC/GSI#604 Undefined values found in radar reflect…
shoyokota Sep 30, 2023
fae4bbf
fix a bug in read_obs.F90 missing N21 for EARS and DBnet (#630)
HaidaoLin-NOAA Sep 30, 2023
25306a2
Turn off enspread reg (#635)
ShunLiu-NOAA Oct 4, 2023
978b7e7
A bug fix in setupps (#638)
hu5970 Oct 6, 2023
f76d872
Replacement of float command with real command (#631)
jderber-NOAA Oct 17, 2023
2cb0f5b
Feature/hafs rtcases (#646)
JingCheng-NOAA Oct 27, 2023
acfe56d
Add FED EnVar DA Capability (#632)
hongli-wang Oct 31, 2023
a3e13da
Modified observation errors for radar-reflectivity observations in pr…
daviddowellNOAA Nov 7, 2023
57e45c4
Fix cool layer output
ADCollard Nov 9, 2023
47f35ee
Fix typo in array index used to write SkinLayerCooling to netcdf diag…
ADCollard Nov 20, 2023
1076cf7
Fix bugs with undefined variable and thread safety in intrad.f90 (#659)
shoyokota Nov 28, 2023
c94bc72
Upgrade to spack-stack libraries on non-production machines (#624)
DavidHuber-NOAA Nov 30, 2023
ea667d9
Cads for andrew (#616)
wx20jjung Dec 4, 2023
44a8f59
Dual-resolution EnVar capability for HAFS ensemble (#652)
XuLu-NOAA Dec 5, 2023
2353eaa
Add assimilation of GLM flash-extent density (FED) observations to En…
daviddowellNOAA Dec 7, 2023
275ee0d
restore the line to initialize 'raterr2' as zero (#668)
xyzemc Dec 20, 2023
12a67af
Merge branch 'NOAA-EMC:develop' into develop
ADCollard Dec 21, 2023
336d6fb
Remove HIRS from regression tests
ADCollard Dec 21, 2023
7f37de3
Remove HIRS from GSI regression tests (#672)
ADCollard Jan 18, 2024
12f8d3e
add clipping treatment for negative values of non-negative tracers (#…
AmandaBack-NOAA Jan 24, 2024
8ed034f
Complete issue #607 (Optimization of multiscale regional runs) (#670)
jderber-NOAA Jan 26, 2024
a898668
Updated detect_machine.sh to be consistent with UFSWM. (#691)
HenryRWinterbottom Jan 31, 2024
a59f8ff
Merge branch 'NOAA-EMC:develop' into develop
ADCollard Feb 6, 2024
94c6a7c
Updates for soil moisture and soil temperature analysis (#675)
ClaraDraper-NOAA Feb 7, 2024
2915685
a quick fix for Issue:A indexing out of bounds issue shown in the glo…
TingLei-daprediction Feb 8, 2024
bae0342
Fix soil temperature/mositure read from RRFS warm-start r… (#683)
xyzemc Feb 9, 2024
cd62003
Adding the dry-bulb air temperature and tv flag in the observation di…
GangZhao-NOAA Feb 13, 2024
86ad20e
update fix submodule for GFS v16.3.12 and soil analysis changes (#695)
RussTreadon-NOAA Feb 13, 2024
74ac594
Upgrade the GSI to Spack-Stack version 1.6.0 (#684)
DavidHuber-NOAA Feb 14, 2024
7c4a571
Fix three bugs found in RRFS test (#705)
hu5970 Feb 23, 2024
fca6bea
CrIS viirs bug fix (#708)
wx20jjung Feb 27, 2024
f282a94
Assimilate GMI in GSI (#692)
xincjin-NOAA Mar 12, 2024
a8d670c
Update fix submodule (Rcov_crisn21) & GSI_BINARY_SOURCE_DIR (#718)
RussTreadon-NOAA Mar 14, 2024
8d740a7
Update read_ozone.f90 to handle GOME data before and after 20240131 1…
RussTreadon-NOAA Mar 18, 2024
dfb958f
Update Hera intel modulefile to Rocky 8 (#715)
RussTreadon-NOAA Mar 18, 2024
4e8107c
Add parallel netcdf read/write from EnKF for sfc files (paranc option…
tsga Mar 19, 2024
2167bc9
Issue 694: Upgrade/refactoring for U and V write-out sub for FV3REG G…
TingLei-daprediction Mar 20, 2024
0026f1e
Merge branch 'NOAA-EMC:develop' into develop
ADCollard Mar 22, 2024
f7e93ab
GSI built with debug mode failed in the global_4densvar (#722)
TingLei-NOAA Mar 24, 2024
e1e854d
Merge branch 'NOAA-EMC:develop' into develop
ADCollard Mar 25, 2024
1cc934e
Add the Multigrid Beta Filter (MGBF) for ensemble localization (#699)…
shoyokota Mar 26, 2024
6d9ebbb
Dsfcalc fix (#727)
ADCollard Mar 26, 2024
b53740a
Fix HAFS GSI debug build and run issues (#679)
XuLu-NOAA Mar 27, 2024
b520021
Merge branch 'NOAA-EMC:develop' into develop
ADCollard Mar 27, 2024
b2fc4fd
add ability to taper analysis perts near top of model (#729)
jswhit Mar 29, 2024
db477e3
Update the QC for the enhanced high-resolution GOES-R mesoscale float…
JingCheng-NOAA Apr 1, 2024
29d9d8f
Adding I/O for direct analysis of near-surface wind gust for RRFS-bas…
GangZhao-NOAA Apr 5, 2024
c556875
Merge branch 'NOAA-EMC:develop' into develop
ADCollard Apr 17, 2024
b401c47
Fix minor thinning annoyances. GSI #731
ADCollard Apr 17, 2024
d75f44a
Two small tweaks to thinning (#734)
ADCollard Apr 18, 2024
457510c
reorder correlated error setup checks (#736)
RussTreadon-NOAA Apr 22, 2024
8e279f9
Update Jet modulefiles to Rocky8 (#733)
InnocentSouopgui-NOAA Apr 25, 2024
8a85d7c
Add _CLDDET.NL to fix and activate CADS in global_4denvar ctest (#740)
wx20jjung Apr 29, 2024
a3a2633
nread bug in read_radar.f90 (#738)
ShunLiu-NOAA Apr 30, 2024
38bdb95
Add module file to compile on AWS (#742)
weihuang-jedi May 7, 2024
88aaa63
Merge branch 'NOAA-EMC:develop' into develop
ADCollard May 7, 2024
042e1d7
Add additional geoval and obs outputs
ADCollard May 7, 2024
ebeaba1
add license (#745)
RussTreadon-NOAA May 8, 2024
c3644a6
Bring branch up to develop
ADCollard May 9, 2024
5be3fa9
Add virtual temperature information
ADCollard May 9, 2024
67cddc0
Bug fixes
ADCollard May 9, 2024
59d7578
Update module files to build gsi on Gaea-C5 (#746)
DavidBurrows-NCO May 20, 2024
6cd87ae
Bug fixes
ADCollard May 30, 2024
8d20eb2
Fix type
ADCollard May 30, 2024
f82dc34
add two band sdl to global_4denvar namelist (#758)
RussTreadon-NOAA Jun 21, 2024
6a87460
update path to global ctest model data (#762)
RussTreadon-NOAA Jun 25, 2024
24b731a
Update RRFS regression test cases (#750)
hu5970 Jun 27, 2024
b37b7d7
Update Jet directories (#763)
DavidHuber-NOAA Jun 27, 2024
529bb79
Updates to build and run on Orion Rocky 9 (#764)
RussTreadon-NOAA Jun 28, 2024
2d8a4e5
Merge branch 'develop' of https://github.com/ADCollard/GSI into develop
ADCollard Jul 2, 2024
38e806e
Merge branch 'develop' into feature/ufo_geovals
ADCollard Jul 2, 2024
c6b35d0
Merge remote-tracking branch 'origin/develop' into feature/ufo_geovals
ADCollard Jul 9, 2024
2745c65
Add observer script
ADCollard Jul 31, 2024
2e62d48
Fix iodaconv.sh path
ADCollard Jul 31, 2024
96aacb6
Small fixes
ADCollard Jul 31, 2024
c069aec
update path
ADCollard Aug 1, 2024
fbc19df
Merge branch 'feature/ufo_geovals' of https://github.com/ADCollard/GS…
ADCollard Aug 1, 2024
235018e
Remove duplicate output
ADCollard Aug 6, 2024
47a6db4
Fix variable types in setupoz.f90
ADCollard Aug 6, 2024
0dcda32
Fix variable types in setupoz.f90
ADCollard Aug 6, 2024
73062e7
Make sure aveage surface temperature is included
ADCollard Aug 8, 2024
ba90137
Add instruments
ADCollard Aug 12, 2024
fd6be62
Use CRTM 2.4.0.1
ADCollard Aug 14, 2024
d9e7c54
Additional changes for CRTM
ADCollard Aug 15, 2024
6f7da62
Fix virtual temperature
ADCollard Oct 10, 2024
0fe60bb
Fix virtual temperature
ADCollard Oct 10, 2024
bfbca87
Fix time window
ADCollard Oct 17, 2024
28bf87d
Add AVHRR cloud fraction
ADCollard Oct 17, 2024
d7ddda2
Merge branch 'feature/ufo_geovals' of https://github.com/ADCollard/GS…
ADCollard Oct 17, 2024
fe5f1d2
fic paren
ADCollard Oct 17, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
The table of contents is too big for display.
Diff view
Diff view
  •  
  •  
  •  
31 changes: 16 additions & 15 deletions .github/workflows/gcc.yml
Original file line number Diff line number Diff line change
Expand Up @@ -15,21 +15,21 @@ env:

# The jobs are split into:
# 1. a dependency build step (setup), and
# 2. a GSI build step (build)
# 2. a GSI build step (gsi)
# The setup is run once and the environment is cached,
# so each build of GSI can reuse the cached dependencies to save time (and compute).
# so each subsequent build of GSI can reuse the cached dependencies to save time (and compute).

jobs:
setup:
runs-on: ubuntu-latest

steps:
# Checkout the GSI to get the ci/spack.yaml file
- name: checkout-gsi
- name: checkout
if: steps.cache-env.outputs.cache-hit != 'true'
uses: actions/checkout@v3
uses: actions/checkout@v4
with:
path: GSI
path: gsi

# Cache spack, compiler and dependencies
- name: cache-env
Expand All @@ -39,33 +39,34 @@ jobs:
path: |
spack
~/.spack
key: spack-${{ runner.os }}-${{ env.cache_key }}-${{ hashFiles('GSI/ci/spack.yaml') }}
key: spack-${{ runner.os }}-${{ env.cache_key }}-${{ hashFiles('gsi/ci/spack.yaml') }}

# Install dependencies using Spack
- name: install-dependencies-with-spack
if: steps.cache-env.outputs.cache-hit != 'true'
run: |
sudo apt-get install cmake
git clone -c feature.manyFiles=true https://github.com/NOAA-EMC/spack.git
git clone -c feature.manyFiles=true https://github.com/JCSDA/spack.git
source spack/share/spack/setup-env.sh
spack env create gsi-env GSI/ci/spack.yaml
spack env create gsi-env gsi/ci/spack.yaml
spack env activate gsi-env
spack compiler find
sudo apt install cmake
spack external find
spack add mpich@3.4.2
spack concretize
spack install -v --fail-fast --dirty
spack clean -a

build:
gsi:
needs: setup
runs-on: ubuntu-latest

steps:
- name: checkout-gsi
uses: actions/checkout@v3
- name: checkout
uses: actions/checkout@v4
with:
path: GSI
path: gsi

- name: cache-env
id: cache-env
Expand All @@ -74,13 +75,13 @@ jobs:
path: |
spack
~/.spack
key: spack-${{ runner.os }}-${{ env.cache_key }}-${{ hashFiles('GSI/ci/spack.yaml') }}
key: spack-${{ runner.os }}-${{ env.cache_key }}-${{ hashFiles('gsi/ci/spack.yaml') }}

- name: build-gsi
- name: build
run: |
source spack/share/spack/setup-env.sh
spack env activate gsi-env
cd GSI
cd gsi
mkdir -p build && cd build
cmake -DCMAKE_INSTALL_PREFIX=../install -DGSI_MODE=Regional -DENKF_MODE=GFS -DBUILD_REG_TESTING=OFF ..
make -j2 VERBOSE=1
Expand Down
47 changes: 28 additions & 19 deletions .github/workflows/intel.yml
Original file line number Diff line number Diff line change
Expand Up @@ -18,21 +18,30 @@ env:

# The jobs are split into:
# 1. a dependency build step (setup), and
# 2. a GSI build step (build)
# 2. a GSI build step (gsi)
# The setup is run once and the environment is cached,
# so each build of GSI can reuse the cached dependencies to save time (and compute).
# so each subsequent build of GSI can reuse the cached dependencies to save time (and compute).

jobs:
setup:
runs-on: ubuntu-latest

steps:
# Free up disk space
- name: free-disk-spack
run: |
df -h
sudo swapoff -a
sudo rm -f /swapfile
sudo apt clean
docker rmi $(docker image ls -aq)

# Checkout the GSI to get the ci/spack.yaml file
- name: checkout-gsi
- name: checkout
if: steps.cache-env.outputs.cache-hit != 'true'
uses: actions/checkout@v3
uses: actions/checkout@v4
with:
path: GSI
path: gsi

# Cache spack, compiler and dependencies
- name: cache-env
Expand All @@ -43,16 +52,15 @@ jobs:
spack
~/.spack
/opt/intel
key: spack-${{ runner.os }}-${{ env.cache_key }}-${{ hashFiles('GSI/ci/spack.yaml') }}
key: spack-${{ runner.os }}-${{ env.cache_key }}-${{ hashFiles('gsi/ci/spack.yaml') }}

- name: install-intel-compilers
if: steps.cache-env.outputs.cache-hit != 'true'
run: |
wget https://apt.repos.intel.com/intel-gpg-keys/GPG-PUB-KEY-INTEL-SW-PRODUCTS.PUB
sudo apt-key add GPG-PUB-KEY-INTEL-SW-PRODUCTS.PUB
echo "deb https://apt.repos.intel.com/oneapi all main" | sudo tee /etc/apt/sources.list.d/oneAPI.list
sudo apt-get update
sudo apt-get install intel-oneapi-dev-utilities intel-oneapi-mpi-devel intel-oneapi-openmp intel-oneapi-compiler-fortran intel-oneapi-compiler-dpcpp-cpp-and-cpp-classic
sudo apt-get install intel-oneapi-dev-utilities intel-oneapi-mpi-devel intel-oneapi-openmp intel-oneapi-compiler-fortran-2023.2.1 intel-oneapi-compiler-dpcpp-cpp-and-cpp-classic-2023.2.1
sudo apt-get clean
echo "source /opt/intel/oneapi/setvars.sh" >> ~/.bash_profile

Expand All @@ -62,31 +70,32 @@ jobs:
run: |
sudo mv /usr/local/ /usr_local_mv
sudo apt-get install cmake
git clone -c feature.manyFiles=true https://github.com/NOAA-EMC/spack.git
git clone -c feature.manyFiles=true https://github.com/JCSDA/spack.git
source spack/share/spack/setup-env.sh
spack env create gsi-env GSI/ci/spack.yaml
spack env create gsi-env gsi/ci/spack.yaml
spack env activate gsi-env
spack compiler find
sudo apt install cmake
spack external find
spack add intel-oneapi-mpi
spack concretize
spack install -v --fail-fast --dirty
spack clean -a

build:
gsi:
needs: setup
runs-on: ubuntu-latest

steps:
- name: checkout-gsi
uses: actions/checkout@v3
with:
path: GSI

- name: install-intel
run: |
echo "source /opt/intel/oneapi/setvars.sh" >> ~/.bash_profile

- name: checkout
uses: actions/checkout@v4
with:
path: gsi

- name: cache-env
id: cache-env
uses: actions/cache@v3
Expand All @@ -95,13 +104,13 @@ jobs:
spack
~/.spack
/opt/intel
key: spack-${{ runner.os }}-${{ env.cache_key }}-${{ hashFiles('GSI/ci/spack.yaml') }}
key: spack-${{ runner.os }}-${{ env.cache_key }}-${{ hashFiles('gsi/ci/spack.yaml') }}

- name: build-gsi
- name: build
run: |
source spack/share/spack/setup-env.sh
spack env activate gsi-env
cd GSI
cd gsi
mkdir -p build && cd build
cmake -DCMAKE_INSTALL_PREFIX=../install -DGSI_MODE=Regional -DENKF_MODE=GFS -DBUILD_REG_TESTING=OFF ..
make -j2 VERBOSE=1
Expand Down
2 changes: 2 additions & 0 deletions CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -29,6 +29,7 @@ endif()
option(OPENMP "Enable OpenMP Threading" OFF)
option(ENABLE_MKL "Use MKL for LAPACK implementation (if available)" ON)
option(BUILD_GSDCLOUD "Build GSD Cloud Analysis Library" OFF)
option(BUILD_MGBF "Build MGBF Library" ON)
option(BUILD_GSI "Build GSI" ON)
option(BUILD_ENKF "Build EnKF" ON)
option(BUILD_REG_TESTING "Build the Regression Testing Suite" OFF)
Expand All @@ -37,6 +38,7 @@ option(BUILD_REG_TESTING "Build the Regression Testing Suite" OFF)
message(STATUS "OPENMP ................. ${OPENMP}")
message(STATUS "ENABLE_MKL ............. ${ENABLE_MKL}")
message(STATUS "BUILD_GSDCLOUD ......... ${BUILD_GSDCLOUD}")
message(STATUS "BUILD_MGBF ............. ${BUILD_MGBF}")
message(STATUS "BUILD_GSI .............. ${BUILD_GSI}")
message(STATUS "BUILD_ENKF ............. ${BUILD_ENKF}")
message(STATUS "BUILD_REG_TESTING ...... ${BUILD_REG_TESTING}")
Expand Down
1 change: 1 addition & 0 deletions INSTALL.md
Original file line number Diff line number Diff line change
Expand Up @@ -79,6 +79,7 @@ CMake allows for various options that can be specified on the command line via `
| `OPENMP` | Enable OpenMP Threading (`OFF`) |
| `ENABLE_MKL` | Use MKL (`ON`), If not found use LAPACK |
| `BUILD_GSDCLOUD` | Build GSD Cloud Library (`OFF`) |
| `BUILD_MGBF` | Build MGBF Library (`ON`) |
| `BUILD_GSI` | Build GSI library and executable (`ON`) |
| `BUILD_ENKF` | Build EnKF library and executable (`ON`) |
| `BUILD_REG_TESTING` | Enable Regression Testing (`ON`) |
Expand Down
157 changes: 157 additions & 0 deletions LICENSE.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,157 @@
### GNU LESSER GENERAL PUBLIC LICENSE

Version 3, 29 June 2007

Copyright (C) 2007 Free Software Foundation, Inc.
<https://fsf.org/>

Everyone is permitted to copy and distribute verbatim copies of this
license document, but changing it is not allowed.

This version of the GNU Lesser General Public License incorporates the
terms and conditions of version 3 of the GNU General Public License,
supplemented by the additional permissions listed below.

#### 0. Additional Definitions.

As used herein, "this License" refers to version 3 of the GNU Lesser
General Public License, and the "GNU GPL" refers to version 3 of the
GNU General Public License.

"The Library" refers to a covered work governed by this License, other
than an Application or a Combined Work as defined below.

An "Application" is any work that makes use of an interface provided
by the Library, but which is not otherwise based on the Library.
Defining a subclass of a class defined by the Library is deemed a mode
of using an interface provided by the Library.

A "Combined Work" is a work produced by combining or linking an
Application with the Library. The particular version of the Library
with which the Combined Work was made is also called the "Linked
Version".

The "Minimal Corresponding Source" for a Combined Work means the
Corresponding Source for the Combined Work, excluding any source code
for portions of the Combined Work that, considered in isolation, are
based on the Application, and not on the Linked Version.

The "Corresponding Application Code" for a Combined Work means the
object code and/or source code for the Application, including any data
and utility programs needed for reproducing the Combined Work from the
Application, but excluding the System Libraries of the Combined Work.

#### 1. Exception to Section 3 of the GNU GPL.

You may convey a covered work under sections 3 and 4 of this License
without being bound by section 3 of the GNU GPL.

#### 2. Conveying Modified Versions.

If you modify a copy of the Library, and, in your modifications, a
facility refers to a function or data to be supplied by an Application
that uses the facility (other than as an argument passed when the
facility is invoked), then you may convey a copy of the modified
version:

- a) under this License, provided that you make a good faith effort
to ensure that, in the event an Application does not supply the
function or data, the facility still operates, and performs
whatever part of its purpose remains meaningful, or
- b) under the GNU GPL, with none of the additional permissions of
this License applicable to that copy.

#### 3. Object Code Incorporating Material from Library Header Files.

The object code form of an Application may incorporate material from a
header file that is part of the Library. You may convey such object
code under terms of your choice, provided that, if the incorporated
material is not limited to numerical parameters, data structure
layouts and accessors, or small macros, inline functions and templates
(ten or fewer lines in length), you do both of the following:

- a) Give prominent notice with each copy of the object code that
the Library is used in it and that the Library and its use are
covered by this License.
- b) Accompany the object code with a copy of the GNU GPL and this
license document.

#### 4. Combined Works.

You may convey a Combined Work under terms of your choice that, taken
together, effectively do not restrict modification of the portions of
the Library contained in the Combined Work and reverse engineering for
debugging such modifications, if you also do each of the following:

- a) Give prominent notice with each copy of the Combined Work that
the Library is used in it and that the Library and its use are
covered by this License.
- b) Accompany the Combined Work with a copy of the GNU GPL and this
license document.
- c) For a Combined Work that displays copyright notices during
execution, include the copyright notice for the Library among
these notices, as well as a reference directing the user to the
copies of the GNU GPL and this license document.
- d) Do one of the following:
- 0) Convey the Minimal Corresponding Source under the terms of
this License, and the Corresponding Application Code in a form
suitable for, and under terms that permit, the user to
recombine or relink the Application with a modified version of
the Linked Version to produce a modified Combined Work, in the
manner specified by section 6 of the GNU GPL for conveying
Corresponding Source.
- 1) Use a suitable shared library mechanism for linking with
the Library. A suitable mechanism is one that (a) uses at run
time a copy of the Library already present on the user's
computer system, and (b) will operate properly with a modified
version of the Library that is interface-compatible with the
Linked Version.
- e) Provide Installation Information, but only if you would
otherwise be required to provide such information under section 6
of the GNU GPL, and only to the extent that such information is
necessary to install and execute a modified version of the
Combined Work produced by recombining or relinking the Application
with a modified version of the Linked Version. (If you use option
4d0, the Installation Information must accompany the Minimal
Corresponding Source and Corresponding Application Code. If you
use option 4d1, you must provide the Installation Information in
the manner specified by section 6 of the GNU GPL for conveying
Corresponding Source.)

#### 5. Combined Libraries.

You may place library facilities that are a work based on the Library
side by side in a single library together with other library
facilities that are not Applications and are not covered by this
License, and convey such a combined library under terms of your
choice, if you do both of the following:

- a) Accompany the combined library with a copy of the same work
based on the Library, uncombined with any other library
facilities, conveyed under the terms of this License.
- b) Give prominent notice with the combined library that part of it
is a work based on the Library, and explaining where to find the
accompanying uncombined form of the same work.

#### 6. Revised Versions of the GNU Lesser General Public License.

The Free Software Foundation may publish revised and/or new versions
of the GNU Lesser General Public License from time to time. Such new
versions will be similar in spirit to the present version, but may
differ in detail to address new problems or concerns.

Each version is given a distinguishing version number. If the Library
as you received it specifies that a certain numbered version of the
GNU Lesser General Public License "or any later version" applies to
it, you have the option of following the terms and conditions either
of that published version or of any later version published by the
Free Software Foundation. If the Library as you received it does not
specify a version number of the GNU Lesser General Public License, you
may choose any version of the GNU Lesser General Public License ever
published by the Free Software Foundation.

If the Library as you received it specifies that a proxy can decide
whether future versions of the GNU Lesser General Public License shall
apply, that proxy's public statement of acceptance of any version is
permanent authorization for you to choose that version for the
Library.
Loading
Loading