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 in initial 3DVar aerosol DA cycling capability #1106

Merged
merged 132 commits into from
Feb 10, 2023
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
132 commits
Select commit Hold shift + click to select a range
5848a84
Update rocoto scripts to call j-jobs
CoryMartin-NOAA Aug 23, 2022
801b0a5
touch j-jobs
CoryMartin-NOAA Aug 23, 2022
7a6dc92
touch ex-scripts
CoryMartin-NOAA Aug 23, 2022
353cd79
Update j-jobs
CoryMartin-NOAA Aug 24, 2022
dd84394
set STRICT to NO
CoryMartin-NOAA Aug 25, 2022
81858d7
Start of initialize script
CoryMartin-NOAA Aug 29, 2022
91c37cd
Dummy ex-scripts
CoryMartin-NOAA Aug 29, 2022
7d9bae2
Merge branch 'develop' into feature/aeroda_jobs
CoryMartin-NOAA Aug 29, 2022
2bad09a
Make all aeroanl jobs use same data dir
CoryMartin-NOAA Aug 31, 2022
8ce5031
Start of initialize script
CoryMartin-NOAA Aug 31, 2022
0858f13
Incremental commit
CoryMartin-NOAA Sep 2, 2022
98504d0
Just save to go talk
CoryMartin-NOAA Sep 2, 2022
d86fd99
Cleanup classes
CoryMartin-NOAA Sep 2, 2022
33fe3e2
Incremental change
CoryMartin-NOAA Sep 6, 2022
a232856
incremental update
CoryMartin-NOAA Sep 6, 2022
616b86c
Fix paths in j-jobs for aero scripts
CoryMartin-NOAA Sep 6, 2022
6afb8a7
Remove pythonpath and print
CoryMartin-NOAA Sep 6, 2022
dfd2bab
More changes
CoryMartin-NOAA Sep 6, 2022
82f5d90
bugfix to get it to work hopefully
CoryMartin-NOAA Sep 6, 2022
520a871
fix logging information
CoryMartin-NOAA Sep 6, 2022
fcc1d4c
Change prints to passes
CoryMartin-NOAA Sep 6, 2022
9e6fc64
Update gdasapp commit; typo fix in parm config; progress towards stag…
CoryMartin-NOAA Sep 8, 2022
2150ed5
working copy of obs
CoryMartin-NOAA Sep 9, 2022
ae1fca7
Update fix file path for aeroanl
CoryMartin-NOAA Sep 9, 2022
197cfa8
Changes to config.aeroanl; working ob/bkg copy; to test yaml write
CoryMartin-NOAA Sep 9, 2022
bed58e7
Lots of changes
CoryMartin-NOAA Sep 9, 2022
bc2015c
Add doc header
CoryMartin-NOAA Sep 9, 2022
f643ffd
Add NPOESS VIS files to copy
CoryMartin-NOAA Sep 11, 2022
1e60ef7
Update finalize ex script
CoryMartin-NOAA Sep 12, 2022
69d5dd9
Update analysis task
CoryMartin-NOAA Sep 12, 2022
37b5dbf
fix config.aeroanl
CoryMartin-NOAA Sep 15, 2022
d47defb
incremental update
CoryMartin-NOAA Sep 15, 2022
ddf6541
Save before lunch
CoryMartin-NOAA Sep 15, 2022
33ae03b
Save diags to rotdir
CoryMartin-NOAA Sep 15, 2022
28c2321
Copy YAML file to rotdir
CoryMartin-NOAA Sep 15, 2022
c2774fd
End of day commit
CoryMartin-NOAA Sep 15, 2022
54af10d
Fix missing cdate_fv3
CoryMartin-NOAA Sep 15, 2022
593f3ea
Changes to workflow to include staticB matrices
Oct 20, 2022
f05ed7e
Changes to workflow to include aero DA with static-B
Oct 31, 2022
5571459
Update gdasapp hashes
CoryMartin-NOAA Nov 1, 2022
1e2a30f
Merge branch 'develop' of https://github.com/noaa-emc/global-workflow…
CoryMartin-NOAA Nov 1, 2022
08ec8c2
Some minor things to get cycling going
CoryMartin-NOAA Nov 1, 2022
a8dac5d
Update hash for gdasapp
CoryMartin-NOAA Nov 1, 2022
f4ffba9
Some small changes to analysis.py
CoryMartin-NOAA Nov 2, 2022
4442243
Generalize jobs to load modules on hera and orion
CoryMartin-NOAA Nov 2, 2022
ade7c36
Support identity B for aero
CoryMartin-NOAA Nov 2, 2022
b904215
Update gdasapp hash
CoryMartin-NOAA Nov 2, 2022
7931a8a
Attempt to fix linter issues for one file
CoryMartin-NOAA Nov 3, 2022
16ea583
another linter check
CoryMartin-NOAA Nov 3, 2022
85218b9
More linter
CoryMartin-NOAA Nov 3, 2022
7204c87
Linter done for two J-jobs before lunch
CoryMartin-NOAA Nov 3, 2022
cd3068a
More linter changes
CoryMartin-NOAA Nov 3, 2022
47bd8b4
more linter stuff
CoryMartin-NOAA Nov 3, 2022
f554b1d
more linter again
CoryMartin-NOAA Nov 3, 2022
1536029
Address reviewer comments by @russtreadon-noaa
CoryMartin-NOAA Nov 7, 2022
0e24cba
Merge branch 'develop' into feature/aeroda_staticb_crm
CoryMartin-NOAA Dec 2, 2022
c80c86f
Fix known bugs before review comments are addressed
CoryMartin-NOAA Dec 2, 2022
3887616
make aerosol da a dependency of fcst if cycling and using aerosols
CoryMartin-NOAA Dec 2, 2022
cd26d7a
Typo
CoryMartin-NOAA Dec 2, 2022
8007a2d
Separate out subclasses
CoryMartin-NOAA Dec 2, 2022
05ce283
cleanup the ex scripts
CoryMartin-NOAA Dec 2, 2022
44a5e02
update commit hash for gdasapp
CoryMartin-NOAA Dec 2, 2022
21e5d61
More tidying up before addressing classes
CoryMartin-NOAA Dec 2, 2022
6f7a6fa
Merge branch 'develop' into feature/aeroda_staticb_crm
CoryMartin-NOAA Dec 7, 2022
c71da55
move gfs module to python/pygfs
CoryMartin-NOAA Dec 7, 2022
9339d60
Modify rocoto jobs to set PYTHONPATH
CoryMartin-NOAA Dec 7, 2022
7292b68
Modify j-jobs
CoryMartin-NOAA Dec 7, 2022
c472fef
lint roller
CoryMartin-NOAA Dec 7, 2022
c743d1d
Incremental save before meeting
CoryMartin-NOAA Dec 7, 2022
0b9f2e6
test for debugging gdasapp
CoryMartin-NOAA Dec 7, 2022
d49e612
Remove py header docstring and change to pygfs
CoryMartin-NOAA Dec 7, 2022
3868d5a
Dumb thing just to confirm ci test is working
CoryMartin-NOAA Dec 7, 2022
2d8cbcf
Save before merge
CoryMartin-NOAA Dec 7, 2022
12b7f9a
Merge branch 'feature/aeroda_staticb_crm' of https://github.com/NOAA-…
CoryMartin-NOAA Dec 7, 2022
76a643c
Start of yaml based copy for stage
CoryMartin-NOAA Dec 7, 2022
4e99947
Create aero_jedi_fix.yaml
CoryMartin-NOAA Dec 7, 2022
5ec625a
remove changes from fsutils
CoryMartin-NOAA Dec 9, 2022
c3d8866
Incremental save
CoryMartin-NOAA Dec 9, 2022
023d50c
Friday afternoon save
CoryMartin-NOAA Dec 9, 2022
b816f9d
Merge branch 'develop' into feature/aeroda_staticb_crm
CoryMartin-NOAA Dec 9, 2022
cb77783
Merge branch 'develop' into feature/aeroda_staticb_crm
CoryMartin-NOAA Dec 13, 2022
fdb6bd8
Changes to aerosol tasks
CoryMartin-NOAA Dec 13, 2022
999baea
Update aero_analysis.py
CoryMartin-NOAA Dec 13, 2022
af61a18
init works; waiting on run to get through queue
CoryMartin-NOAA Dec 14, 2022
26acb44
save before pycodestyle
CoryMartin-NOAA Dec 14, 2022
a7b0d26
pycodestyle
CoryMartin-NOAA Dec 14, 2022
9ea9e9f
pycodestyle part deux
CoryMartin-NOAA Dec 14, 2022
eb915d0
fix where aprun will not work properly in quotes
CoryMartin-NOAA Dec 14, 2022
27f3383
Save before merge
CoryMartin-NOAA Dec 15, 2022
4855ec7
Merge branch 'develop' into feature/aeroda_staticb_crm
CoryMartin-NOAA Dec 15, 2022
08e0428
Change j-jobs
CoryMartin-NOAA Dec 15, 2022
79af76f
add RUN
CoryMartin-NOAA Dec 15, 2022
bae934f
Update jobs/JGDAS_GLOBAL_AERO_ANALYSIS_INITIALIZE
CoryMartin-NOAA Dec 15, 2022
6e9c953
Merge branch 'develop' into feature/aeroda_staticb_crm
CoryMartin-NOAA Jan 20, 2023
175648f
Changes to address some reviewer comments
CoryMartin-NOAA Jan 20, 2023
2383214
Update to gdasapp hash right before ioda naming convention change
CoryMartin-NOAA Jan 20, 2023
d309030
Use the j-job header properly
CoryMartin-NOAA Jan 20, 2023
8706ef8
Minor fixes to get cycling working on hera
CoryMartin-NOAA Jan 25, 2023
5af46f8
make the linter happy
CoryMartin-NOAA Jan 25, 2023
54b6432
make the python linter happy too
CoryMartin-NOAA Jan 25, 2023
27a104a
Merge branch 'develop' into feature/aeroda_staticb_crm
CoryMartin-NOAA Jan 25, 2023
a43a428
reviewer comments
CoryMartin-NOAA Jan 25, 2023
15e7e74
more lint
CoryMartin-NOAA Jan 25, 2023
635501a
Make aero static B more generic
CoryMartin-NOAA Jan 25, 2023
725a833
Add brief documentation for each ex-script
CoryMartin-NOAA Jan 25, 2023
57a8a84
Minor thing
CoryMartin-NOAA Jan 25, 2023
db9193b
JGDAS_GLOBAL to JGLOBAL
CoryMartin-NOAA Jan 26, 2023
f038793
a few updates after the discussion
aerorahul Jan 26, 2023
065ccba
Make some little tweaks
aerorahul Jan 27, 2023
b70cfe4
use task_config in the class
aerorahul Jan 27, 2023
904f1eb
Merge branch 'feature/aeroda_staticb_crm' into patch/aeroda_staticb_crm
aerorahul Jan 27, 2023
b48383a
no need for the configure method
aerorahul Jan 27, 2023
c43684f
Merge pull request #1288 from aerorahul/patch/aeroda_staticb_crm
CoryMartin-NOAA Jan 30, 2023
fd4aca9
PEP8 changes
CoryMartin-NOAA Jan 30, 2023
7bc3d2b
Add workflow env to build; fix some minor issues
CoryMartin-NOAA Jan 30, 2023
4a1518b
Merge branch 'feature/aeroda_staticb_crm' of https://github.com/NOAA-…
CoryMartin-NOAA Jan 30, 2023
4cb8ab7
end of day commit
CoryMartin-NOAA Jan 30, 2023
3c23875
Save to push
CoryMartin-NOAA Feb 6, 2023
32aef20
make get_bkg and get_berror generic to all analyses
CoryMartin-NOAA Feb 6, 2023
8e69275
Find ones self
CoryMartin-NOAA Feb 6, 2023
7581bec
init job runs again
CoryMartin-NOAA Feb 6, 2023
9c988bf
leading zeros
CoryMartin-NOAA Feb 6, 2023
6c5ae54
Working now need to clean up
CoryMartin-NOAA Feb 6, 2023
186bf79
Consolidate BUMP file list generation; use tileX syntax
CoryMartin-NOAA Feb 6, 2023
ecd0cca
Starting to lint trap
CoryMartin-NOAA Feb 6, 2023
fdf4139
Merge branch 'develop' into feature/aeroda_staticb_crm
CoryMartin-NOAA Feb 6, 2023
46e6319
Add documentation; make incvars a YAML
CoryMartin-NOAA Feb 6, 2023
58c4c71
pycodestyle again
CoryMartin-NOAA Feb 6, 2023
8ec0457
Update analysis.py
CoryMartin-NOAA Feb 6, 2023
6d65542
Update analysis.py
CoryMartin-NOAA Feb 6, 2023
51e070f
Apply suggestions from code review
CoryMartin-NOAA Feb 7, 2023
68d5ca5
Fix PYTHONPATH
CoryMartin-NOAA Feb 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
Prev Previous commit
Next Next commit
Changes to workflow to include staticB matrices
  • Loading branch information
Andrew Tangborn authored and Andrew Tangborn committed Oct 20, 2022
commit 593f3ea54b3e8a5abcbef5fac4dcea911b9d69ec
4 changes: 3 additions & 1 deletion parm/config/config.aeroanl
Original file line number Diff line number Diff line change
Expand Up @@ -8,8 +8,10 @@ echo "BEGIN: config.aeroanl"
export OBS_YAML_DIR=$HOMEgfs/sorc/gdas.cd/parm/aero/obs/config/
export OBS_LIST=$HOMEgfs/sorc/gdas.cd/parm/aero/obs/lists/gdas_aero_prototype.yaml
export AEROVARYAML=$HOMEgfs/sorc/gdas.cd/parm/aero/variational/3dvar_gfs_aero.yaml
export BERROR_YAML=$HOMEgfs/sorc/gdas.cd/parm/aero/berror/staticb_identity.yaml
export BERROR_YAML_DIR=$HOMEgfs/sorc/gdas.cd/parm/aero/berror/
export BERROR_YAML=$HOMEgfs/sorc/gdas.cd/parm/aero/berror/staticb_bump_aero.yaml
export FV3JEDI_FIX=$HOMEgfs/fix/fix_gdas
export BERROR_DATA_DIR=/work/noaa/da/Andrew.Tangborn/staticB/c96/base

export io_layout_x=1
export io_layout_y=1
Expand Down
34 changes: 31 additions & 3 deletions ush/gfs/task/analysis.py
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,9 @@ def __init__(self, config):
self.fv3jedi_fix = config['FV3JEDI_FIX']
self.obs_list_yaml = config['OBS_LIST']
self.obs_yaml_dir = config['OBS_YAML_DIR']
self.berror_dir = config['BERROR_DATA_DIR']
self.berror_yaml = config['BERROR_YAML']
self.berror_yaml_dir = config['BERROR_YAML_DIR']
self.component = config['COMPONENT']
self.cdump = config['CDUMP']

Expand Down Expand Up @@ -58,6 +61,16 @@ def get_obs_dict(self):
obs_dict[os.path.join(os.environ['COMIN_OBS'], basename)] = obfile
RussTreadon-NOAA marked this conversation as resolved.
Show resolved Hide resolved
return obs_dict

def get_staticb_dict(self):
"""
get dictionary of staticb files to copy/use
based on the specified configuration.
"""
import ufsda # temporary until this is in workflow
import yaml
with open(self.berror_yaml, 'r') as yamlopen:
berror_yaml_dict = yaml.safe_load(yamlopen)

def stage_obs(self, filedict):
logging.info('Staging observations')
self.stage(filedict, skip_missing=True)
Expand All @@ -74,7 +87,9 @@ def stage_fix(self, filedict):
logging.info('Finished staging fix files')

def stage_berror(self, filedict):
logging.info('Only using identity B for now... no staging performed')
logging.info('Staging staticb files')
self.stage(filedict)
loggin.info('Finished staging staticb files')

def stage(self, filedict, skip_missing=False):
for src, dest in filedict.items():
Expand Down Expand Up @@ -123,7 +138,7 @@ def initialize(self):
self.stage_fix(fix_dict)
crtm_fix_dict = self.get_crtm_coeff_dict()
self.stage_crtm(crtm_fix_dict)
self.stage_berror({})
self.stage_berror(self.get_berror_dict())
bkg_dict = self.get_bkg_dict()
self.stage_bkg(bkg_dict)
yaml_config = {
Copy link
Contributor

Choose a reason for hiding this comment

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

Instead of hard-coding a bunch of things, can this just be another yaml file with templates that get filled in?

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Maybe? Will need to think about it, I don't see why not.

Expand All @@ -132,7 +147,7 @@ def initialize(self):
'DIAG_DIR': 'diags',
'CRTM_COEFF_DIR': 'crtm',
'OBS_PREFIX': os.environ['OPREFIX'],
'fv3jedi_staticb_dir': 'berror',
'fv3jedi_staticb_aero_dir': 'berror',
'fv3jedi_fix_dir': 'fv3jedi',
'fv3jedi_fieldmetadata_dir': 'fv3jedi',
'OBS_DATE': os.environ['CDATE'],
Expand Down Expand Up @@ -282,6 +297,19 @@ def get_bkg_dict(self):
bkg_dict[os.path.join(rst_dir, basename)] = os.path.join(self.datadir, 'bkg', basename)
return bkg_dict

def get_berror_dict(self):
"""
Return dict of src/dest pairs for berror
"""

ntiles = 6 # global
# aerosol static-B needs nicas, cor_rh, cor_rv and stddev files.
b_dir = self.berror_dir
berror_dict = {}
for t in range(1,ntiles+1):
berror_dict[os.path.join(b_dir, f'20160630.000000.cor_rh.fv_tracer.res.tile{t}.nc')] = os.path.join(self.datadir, 'berror', f'20160630.000000.cor_rh.fv_tracer.res.tile{t}.nc')


def get_crtm_coeff_dict(self):
coeff_file_dict = {
os.path.join(self.fv3jedi_fix,
Expand Down