-
Notifications
You must be signed in to change notification settings - Fork 35
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
Remove redundant code in hco_extlist_mod.F90 #218
Conversation
src/Core/hco_extlist_mod.F90 - Routine GetExtSpcVal_Dr has a DO loop over species where we test if the optional arguments for spcScal_sp, spcScal_int, spcScal_char are passed, and if so, then we populate them. - But this is redundant, as the code to handle spcScal_sp, spcScal_int, and spcScal_char can be moved to the overloaded module routines (GetExtSpcVal_sp, GetExtSpcVal_int, GetExtSpcVal_char). We have done this. - Removed GetExtSpcVal_Dr, as it is no longer needed. - Updated comments, cosmetic changes Signed-off-by: Bob Yantosca <yantosca@seas.harvard.edu>
All GEOS-Chem Classic integration tests except TOMAS passed: ==============================================================================
GEOS-Chem Classic: Execution Test Results
GCClassic #ae031f8 GEOS-Chem and HEMCO submodule updates: Update transport tracer simulation for consistency with GMAO's tracer gridded component
GEOS-Chem #a89ba6868 Merge PR #1816 (branch 'feature/update-transport-tracers') into dev/14.2.0
HEMCO #bf53c91 Remove extraneous routine GetExtSpcVal_Dr in hco_extlist_mod.F90
Using 24 OpenMP threads
Number of execution tests: 26
Submitted as SLURM job: 58432379
==============================================================================
Execution tests:
------------------------------------------------------------------------------
gc_05x0625_NA_47L_merra2_CH4........................Execute Simulation....PASS
gc_05x0625_NA_47L_merra2_fullchem...................Execute Simulation....PASS
gc_4x5_47L_merra2_fullchem..........................Execute Simulation....PASS
gc_4x5_47L_merra2_fullchem_TOMAS15..................Execute Simulation....FAIL
gc_4x5_47L_merra2_fullchem_TOMAS40..................Execute Simulation....FAIL
gc_4x5_merra2_aerosol...............................Execute Simulation....PASS
gc_4x5_merra2_carbon................................Execute Simulation....PASS
gc_4x5_merra2_CH4...................................Execute Simulation....PASS
gc_4x5_merra2_CO2...................................Execute Simulation....PASS
gc_4x5_merra2_fullchem..............................Execute Simulation....PASS
gc_4x5_merra2_fullchem_aciduptake...................Execute Simulation....PASS
gc_4x5_merra2_fullchem_APM..........................Execute Simulation....PASS
gc_4x5_merra2_fullchem_benchmark....................Execute Simulation....PASS
gc_4x5_merra2_fullchem_complexSOA...................Execute Simulation....PASS
gc_4x5_merra2_fullchem_complexSOA_SVPOA.............Execute Simulation....PASS
gc_4x5_merra2_fullchem_LuoWd........................Execute Simulation....PASS
gc_4x5_merra2_fullchem_marinePOA....................Execute Simulation....PASS
gc_4x5_merra2_fullchem_RRTMG........................Execute Simulation....PASS
gc_4x5_merra2_Hg....................................Execute Simulation....PASS
gc_4x5_merra2_metals................................Execute Simulation....PASS
gc_4x5_merra2_POPs_BaP..............................Execute Simulation....PASS
gc_4x5_merra2_tagCH4................................Execute Simulation....PASS
gc_4x5_merra2_tagCO.................................Execute Simulation....PASS
gc_4x5_merra2_tagO3.................................Execute Simulation....PASS
gc_4x5_merra2_TransportTracers......................Execute Simulation....PASS
gc_4x5_merra2_TransportTracers_LuoWd................Execute Simulation....PASS
Summary of test results:
------------------------------------------------------------------------------
Execution tests passed: 24
Execution tests failed: 2
Execution tests not yet completed: 0 The reason for the failure is the update to the TransportTracers. SF6 is now a transport tracer but this conflicts with the TOMAS SF6 sulfate species. A fix for this will be forthcoming later. ===============================================================================
GEOS-Chem ERROR: Is_Gas and Is_Aerosol are both TRUE for species SF6!
-> at Init_Species_Database (in module Headers/species_database_mod.F90
===============================================================================
===============================================================================
GEOS-Chem ERROR: Error encountered in routine "Init_Species_Database"!
-> at Init_State_Chm (in module Headers/state_chm_mod.F90)
===============================================================================
===============================================================================
GEOS-Chem ERROR: Error encountered within call to "Init_State_Chm"!
-> at GC_Init_StateObj (in GeosCore/gc_environment_mod.F90)
===============================================================================
===============================================================================
GEOS-CHEM ERROR: Error encountered in "GC_Init_StateObj!"!
STOP at -> at GEOS-Chem (in GeosCore/main.F90)
===============================================================================
Program received signal SIGSEGV: Segmentation fault - invalid memory reference. |
All GCHP integration tests except TransportTracers passed: ==============================================================================
GCHP: Execution Test Results
GCClassic #318f718 GEOS-Chem and HEMCO submodule updates: Update transport tracer simulation for consistency with GMAO's tracer gridded component
GEOS-Chem #a89ba6868 Merge PR #1816 (branch 'feature/update-transport-tracers') into dev/14.2.0
HEMCO #bf53c91 Remove extraneous routine GetExtSpcVal_Dr in hco_extlist_mod.F90
Number of execution tests: 5
Submitted as SLURM job: 58434234
==============================================================================
Execution tests:
------------------------------------------------------------------------------
gchp_merra2_fullchem................................Execute Simulation....PASS
gchp_merra2_fullchem_benchmark......................Execute Simulation....PASS
gchp_merra2_fullchem_RRTMG..........................Execute Simulation....PASS
gchp_merra2_tagO3...................................Execute Simulation....PASS
gchp_merra2_TransportTracers........................Execute Simulation....FAIL
Summary of test results:
------------------------------------------------------------------------------
Execution tests passed: 4
Execution tests failed: 1
Execution tests not yet completed: 0 The error is: GEOS-Chem ERROR [0011]: The mapData%slot2Id array corresponding to collection "BudgetEmisDryDepFull"
contains missing values! This can indicate that this collection is either undefined or turned off.
Please check the HISTORY.rc configuration file in your run directory.
--> LOCATION: -> at Get_Mapping (in module Headers/state_diag_mod.F90)
GEOS-Chem ERROR [0011]: Error encountered in "Get_Mapping": BudgetEmisDryDepFull
--> LOCATION: -> at Get_MapData_and_NumSlots (in module Headers/state_diag_mod.F90)
GEOS-Chem ERROR [0011]: Error encountered in "Get_MapData_and_NumSlots"!
--> LOCATION: -> at Init_and_Register_R8_3D (in module Headers/state_diag_mod.F90)
GEOS-Chem ERROR [0011]: Error encountered in "Init_and_Register", diagID =BudgetEmisDryDepFull
--> LOCATION: -> at Init_State_Diag (in Headers/state_diag_mod.F90)
GEOS-Chem ERROR [0011]: Error encountered within call to "Init_State_Diag"!
--> LOCATION: -> at GC_Init_StateObj (in GeosCore/gc_environment_mod.F90)
pe=00011 FAIL at line=00250 gchp_chunk_mod.F90 <Error calling GC_Init_StateObj>
pe=00011 FAIL at line=01383 Chem_GridCompMod.F90 <status=1>
pe=00011 FAIL at line=01807 MAPL_Generic.F90 <status=1> Tagging @msulprizio |
The error is that the GCHP 'BudgetEmisDryDepFull_Rn222 ', 'GCHPchem',
'BudgetEmisDryDepFull_Pb210 ', 'GCHPchem',
'BudgetEmisDryDepFull_Pb210s ', 'GCHPchem',
'BudgetEmisDryDepFull_Be7 ', 'GCHPchem',
'BudgetEmisDryDepFull_Be7s ', 'GCHPchem',
'BudgetEmisDryDepFull_Be10 ', 'GCHPchem',
'BudgetEmisDryDepFull_Be10s ', 'GCHPchem',
'BudgetEmisDryDepFull_PassiveTracer ', 'GCHPchem',
'BudgetEmisDryDepFull_SF6Tracer ', 'GCHPchem',
'BudgetEmisDryDepFull_CH3ITracer ', 'GCHPchem',
'BudgetEmisDryDepFull_COAnthroEmis25dayTracer ', 'GCHPchem',
'BudgetEmisDryDepFull_COAnthroEmis50dayTracer ', 'GCHPchem',
'BudgetEmisDryDepFull_COUniformEmis25dayTracer', 'GCHPchem', |
The GCHP integration test issue should be fixed by geoschem/geos-chem#1840. A new set of integration tests has been submitted. |
src/Core/hco_extlist_mod.F90 - In routine GetExtSpcVal_sp, RC is now INTENT(OUT) - Fixed indentation for END SUBROUTINE statements Signed-off-by: Bob Yantosca <yantosca@seas.harvard.edu>
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
CHANGELOG.md needs to be updated. Otherwise, looks good to merge.
CHANGELOG.md - Added comment about the removal of superfluous routine GetExtSpcVal_Dr from src/Core/hco_extlist_mod.F90 Signed-off-by: Bob Yantosca <yantosca@seas.harvard.edu>
Thanks @msulprizio. The changelog has been updated in commit 46f62ed. |
This PR has been merged up to the HEMCO 3.7.1 development branch. Integration tests are now running. |
After merging on top of GEOS-Chem PR #1808 and HEMCO PR #215, all GEOS-Chem Classic integration tests passed (except for TOMAS, which will be fixed later). ==============================================================================
GEOS-Chem Classic: Execution Test Results
GCClassic #93e58a2 Merge PR #1857 (Update minimum KPP version for fullchem to 3.0.0)
GEOS-Chem #5487d702c Merge PR #1808 (Prevent segfaults in SatDiagn; add SatDiagnEdge)
HEMCO #bb3b465 Merge PR #218 (Remove redundant code in hco_extlist_mod.F90)
Using 24 OpenMP threads
Number of execution tests: 26
Submitted as SLURM job: 62039887
==============================================================================
Execution tests:
------------------------------------------------------------------------------
gc_05x0625_NA_47L_merra2_CH4........................Execute Simulation....PASS
gc_05x0625_NA_47L_merra2_fullchem...................Execute Simulation....PASS
gc_4x5_47L_merra2_fullchem..........................Execute Simulation....PASS
gc_4x5_47L_merra2_fullchem_TOMAS15..................Execute Simulation....FAIL
gc_4x5_47L_merra2_fullchem_TOMAS40..................Execute Simulation....FAIL
gc_4x5_merra2_aerosol...............................Execute Simulation....PASS
gc_4x5_merra2_carbon................................Execute Simulation....PASS
gc_4x5_merra2_CH4...................................Execute Simulation....PASS
gc_4x5_merra2_CO2...................................Execute Simulation....PASS
gc_4x5_merra2_fullchem..............................Execute Simulation....PASS
gc_4x5_merra2_fullchem_aciduptake...................Execute Simulation....PASS
gc_4x5_merra2_fullchem_APM..........................Execute Simulation....PASS
gc_4x5_merra2_fullchem_benchmark....................Execute Simulation....PASS
gc_4x5_merra2_fullchem_complexSOA...................Execute Simulation....PASS
gc_4x5_merra2_fullchem_complexSOA_SVPOA.............Execute Simulation....PASS
gc_4x5_merra2_fullchem_LuoWd........................Execute Simulation....PASS
gc_4x5_merra2_fullchem_marinePOA....................Execute Simulation....PASS
gc_4x5_merra2_fullchem_RRTMG........................Execute Simulation....PASS
gc_4x5_merra2_Hg....................................Execute Simulation....PASS
gc_4x5_merra2_metals................................Execute Simulation....PASS
gc_4x5_merra2_POPs_BaP..............................Execute Simulation....PASS
gc_4x5_merra2_tagCH4................................Execute Simulation....PASS
gc_4x5_merra2_tagCO.................................Execute Simulation....PASS
gc_4x5_merra2_tagO3.................................Execute Simulation....PASS
gc_4x5_merra2_TransportTracers......................Execute Simulation....PASS
gc_4x5_merra2_TransportTracers_LuoWd................Execute Simulation....PASS
Summary of test results:
------------------------------------------------------------------------------
Execution tests passed: 24
Execution tests failed: 2
Execution tests not yet completed: 0 Also, most integration tests were identical to GEOS-Chem PR #1808 and HEMCO PR #215, except for those with known parallelization issues. Also note, the TOMAS integration tests list identical but this is because they failed in both Ref & Dev versions. Checking gc_05x0625_NA_47L_merra2_CH4
-> No differences in OutputDir
-> No differences in Restarts
Checking gc_05x0625_NA_47L_merra2_fullchem
-> No differences in OutputDir
-> No differences in Restarts
Checking gc_4x5_47L_merra2_fullchem
-> No differences in OutputDir
-> No differences in Restarts
Checking gc_4x5_47L_merra2_fullchem_TOMAS15
-> No differences in OutputDir
-> No differences in Restarts
Checking gc_4x5_47L_merra2_fullchem_TOMAS40
-> No differences in OutputDir
-> No differences in Restarts
Checking gc_4x5_merra2_aerosol
-> No differences in OutputDir
-> No differences in Restarts
Checking gc_4x5_merra2_carbon
-> No differences in OutputDir
-> No differences in Restarts
Checking gc_4x5_merra2_CH4
-> No differences in OutputDir
-> No differences in Restarts
Checking gc_4x5_merra2_CO2
-> No differences in OutputDir
-> No differences in Restarts
Checking gc_4x5_merra2_fullchem
-> No differences in OutputDir
-> No differences in Restarts
Checking gc_4x5_merra2_fullchem_aciduptake
-> No differences in OutputDir
-> No differences in Restarts
Checking gc_4x5_merra2_fullchem_APM
-> 3 differences found in OutputDir
* GCC_14.2.1_r7/rundirs/gc_4x5_merra2_fullchem_APM/OutputDir/GEOSChem.Metrics.20190701_0000z.nc4
GCC_14.2.1_r8/rundirs/gc_4x5_merra2_fullchem_APM/OutputDir/GEOSChem.Metrics.20190701_0000z.nc4
* GCC_14.2.1_r7/rundirs/gc_4x5_merra2_fullchem_APM/OutputDir/GEOSChem.SpeciesConc.20190701_0000z.nc4
GCC_14.2.1_r8/rundirs/gc_4x5_merra2_fullchem_APM/OutputDir/GEOSChem.SpeciesConc.20190701_0000z.nc4
* GCC_14.2.1_r7/rundirs/gc_4x5_merra2_fullchem_APM/OutputDir/HEMCO_diagnostics.201907010000.nc
GCC_14.2.1_r8/rundirs/gc_4x5_merra2_fullchem_APM/OutputDir/HEMCO_diagnostics.201907010000.nc
-> 1 difference found in Restarts
* GCC_14.2.1_r7/rundirs/gc_4x5_merra2_fullchem_APM/Restarts/GEOSChem.Restart.20190701_0100z.nc4
GCC_14.2.1_r8/rundirs/gc_4x5_merra2_fullchem_APM/Restarts/GEOSChem.Restart.20190701_0100z.nc4
Checking gc_4x5_merra2_fullchem_benchmark
-> No differences in OutputDir
-> No differences in Restarts
Checking gc_4x5_merra2_fullchem_complexSOA
-> No differences in OutputDir
-> No differences in Restarts
Checking gc_4x5_merra2_fullchem_complexSOA_SVPOA
-> No differences in OutputDir
-> No differences in Restarts
Checking gc_4x5_merra2_fullchem_LuoWd
-> No differences in OutputDir
-> No differences in Restarts
Checking gc_4x5_merra2_fullchem_marinePOA
-> No differences in OutputDir
-> No differences in Restarts
Checking gc_4x5_merra2_fullchem_RRTMG
-> 1 difference found in OutputDir
* GCC_14.2.1_r7/rundirs/gc_4x5_merra2_fullchem_RRTMG/OutputDir/GEOSChem.RRTMG.20190701_0000z.nc4
GCC_14.2.1_r8/rundirs/gc_4x5_merra2_fullchem_RRTMG/OutputDir/GEOSChem.RRTMG.20190701_0000z.nc4
-> No differences in Restarts
Checking gc_4x5_merra2_Hg
-> 2 differences found in OutputDir
* GCC_14.2.1_r7/rundirs/gc_4x5_merra2_Hg/OutputDir/GEOSChem.SpeciesConc.20190101_0000z.nc4
GCC_14.2.1_r8/rundirs/gc_4x5_merra2_Hg/OutputDir/GEOSChem.SpeciesConc.20190101_0000z.nc4
* GCC_14.2.1_r7/rundirs/gc_4x5_merra2_Hg/OutputDir/HEMCO_diagnostics.201901010000.nc
GCC_14.2.1_r8/rundirs/gc_4x5_merra2_Hg/OutputDir/HEMCO_diagnostics.201901010000.nc
-> 1 difference found in Restarts
* GCC_14.2.1_r7/rundirs/gc_4x5_merra2_Hg/Restarts/GEOSChem.Restart.20190101_0100z.nc4
GCC_14.2.1_r8/rundirs/gc_4x5_merra2_Hg/Restarts/GEOSChem.Restart.20190101_0100z.nc4
Checking gc_4x5_merra2_metals
-> No differences in OutputDir
-> No differences in Restarts
Checking gc_4x5_merra2_POPs_BaP
-> No differences in OutputDir
-> No differences in Restarts
Checking gc_4x5_merra2_tagCH4
-> No differences in OutputDir
-> No differences in Restarts
Checking gc_4x5_merra2_tagCO
-> No differences in OutputDir
-> No differences in Restarts
Checking gc_4x5_merra2_tagO3
-> No differences in OutputDir
-> No differences in Restarts
Checking gc_4x5_merra2_TransportTracers
-> No differences in OutputDir
-> No differences in Restarts
Checking gc_4x5_merra2_TransportTracers_LuoWd
-> No differences in OutputDir
-> No differences in Restarts |
After merging on top of GEOS-Chem PR #1808 and HEMCO PR #215, all GCHP integration tests passed (except for TOMAS, which will be fixed later). ==============================================================================
GCHP: Execution Test Results
GCClassic #d023bc5 GEOS-Chem submod update: Merge PR #1808 (SatDiagn diagnostic fixes)
GEOS-Chem #5487d702c Merge PR #1808 (Prevent segfaults in SatDiagn; add SatDiagnEdge)
HEMCO #bb3b465 Merge PR #218 (Remove redundant code in hco_extlist_mod.F90)
Number of execution tests: 5
Submitted as SLURM job: 62040037
==============================================================================
Execution tests:
------------------------------------------------------------------------------
gchp_merra2_fullchem................................Execute Simulation....PASS
gchp_merra2_fullchem_benchmark......................Execute Simulation....PASS
gchp_merra2_fullchem_RRTMG..........................Execute Simulation....PASS
gchp_merra2_tagO3...................................Execute Simulation....PASS
gchp_merra2_TransportTracers........................Execute Simulation....PASS
Summary of test results:
------------------------------------------------------------------------------
Execution tests passed: 5
Execution tests failed: 0
Execution tests not yet completed: 0
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
%%% All execution tests passed! %%%
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% Also, all GCHP integration tests were identical to GEOS-Chem PR #1808 and HEMCO PR #215. Checking gchp_merra2_fullchem
-> No differences in OutputDir
-> No differences in Restarts
Checking gchp_merra2_fullchem_benchmark
-> No differences in OutputDir
-> No differences in Restarts
Checking gchp_merra2_fullchem_RRTMG
-> No differences in OutputDir
-> No differences in Restarts
Checking gchp_merra2_tagO3
-> No differences in OutputDir
-> No differences in Restarts
Checking gchp_merra2_TransportTracers
-> No differences in OutputDir
-> No differences in Restarts |
Name and Institution (Required)
Name: Bob Yantosca
Institution: Harvard + GCST
Confirm you have reviewed the following documentation
Describe the update
This PR is based on an investigation into geoschem/geos-chem#1827. In routine
HEMCO/src/Core/hco_extlist_mod.F90
, there are overloaded routines:which call a common routine
GetExtSpcVal_Dr
, in which there is a loop over species. For each species, there are IF blocks that test whether the optional output argumentsspcScal_sp
,spcScal_int
,spcScal_char
are called.This is redundant, as the code to populate
spcScal_sp
can be directly moved into routineGetExtSpcVal_sp
, the code to populatespcScal_int
can be moved intoGetExtSpcVal_int
, and the code to populatespcScal_char
can be moved intoGetExtSpcVal_char
. This will allow us to remove the unnecessaryGetExtSpcVal_Dr
routine.Expected changes
None, this is a zero-diff update
Reference(s)
N/A
Related Github Issue(s)
See geoschem/geos-chem#1827
Integration tests pending