HWRF
trunk@4391
|
Creates the post-processing for the HWRF forecast job. More...
Creates the post-processing for the HWRF forecast job.
Creates and configures all tasks related to the post-processing system. This includes the post, regribber, trackers, and any NHC-specific product generation, as well as some data delivery settings. Everything is made configurable via the hwrf.config.HWRFConfig system.
This class is configurable through config file options:
Config options have certain formats:
The product names in productcom and productintercom follow a certain pattern:
In the second example, here is what each component means:
Definition at line 258 of file hwrfsystem.py.
Public Member Functions | |
def | __init__ (self, ds, conf, section, runwrf, wrf, postdoms, wrfdoms, moad, storm1inner, storm1outer, kwargs) |
Constructor for HWRFForecastPostProcessing. More... | |
def | make_nonsatpost |
Creates the non-satellite post-processor. More... | |
def | make_satpost |
Creates the satellite post-processor. More... | |
def | make_wrfcopier |
Generates the WRF input/output copier task. More... | |
def | make_gribber_tracker |
Generate the regribbing objects and the main tracker. More... | |
def | make_extra_trackers (self) |
Generates intermediate and outermost domain trackers. More... | |
![]() | |
def | __init__ (self, dstore, conf, section, taskname=None, workdir=None, outdir=None, storminfo=UNSPECIFIED, taskvars=UNSPECIFIED, kwargs) |
Creates an HWRFTask. More... | |
def | isfakestorm (self) |
def | ismultistorm (self) |
def | get_workdir (self) |
Returns the directory the class should work in, as set by the "workdir" metadata value. More... | |
def | set_workdir (self, val) |
Sets the directory the class should work in. More... | |
def | get_outdir (self) |
Gets the directory that should receive output data. More... | |
def | set_outdir (self, val) |
Sets the directory that should receive output data. More... | |
def | realtime (self) |
Is this job a real-time forecast job? More... | |
def | redirect (self) |
Should subprograms' outputs be redirected to separate files? | |
def | scrub (self) |
Should temporary files be deleted as soon as they are not needed? | |
def | tvset (self, opt, val) |
Sets a taskvar option's value. More... | |
def | tvdel (self, opt) |
Deletes an object-local value set by tvset. More... | |
def | tvget (self, opt) |
Gets a taskvar's value. More... | |
def | tvhave |
Is a taskvar set? More... | |
def | taskvars (self) |
The dict of object-local values used for string substitution. More... | |
def | confint |
Alias for self.conf.getint for section self.section. More... | |
def | confstr |
Alias for self.conf.getstr for section self.section. More... | |
def | conffloat |
Alias for self.conf.getfloat for section self.section. More... | |
def | confbool |
Alias for self.conf.getbool for section self.section. More... | |
def | confget |
Alias for self.conf.get for section self.section. More... | |
def | confitems |
Alias for self.conf.items for section self.section. More... | |
def | confstrinterp (self, string, section=None, kwargs) |
Alias for self.icstr for backward compatibility. More... | |
def | conftimestrinterp (self, string, ftime, atime=None, section=None, kwargs) |
Alias for self.timestr for backward comaptibility. More... | |
def | confraw |
Get a raw configuration value before string expansion. More... | |
def | icstr (self, string, section=None, kwargs) |
Expands a string in the given conf section. More... | |
def | timestr (self, string, ftime, atime=None, section=None, kwargs) |
Expands a string in the given conf section, including time vars. More... | |
def | getdir |
Alias for hwrf.config.HWRFConfig.get() for the "dir" section. More... | |
def | getexe |
Alias for hwrf.config.HWRFConfig.get() for the "exe" section. More... | |
def | getconf (self) |
Returns this HWRFTask's hwrf.config.HWRFConfig object. More... | |
def | getsection (self) |
Returns this HWRFTask's section name in the HWRFConfig. More... | |
def | log |
Obtain a logging domain. More... | |
def | inputiter (self) |
Iterates over all inputs required by this task. More... | |
![]() | |
def | __init__ (self, dstore, taskname, logger=None, kwargs) |
Task constructor. More... | |
def | jlogfile (self) |
returns the jlogfile logger. More... | |
def | postmsg (self, message, args, kwargs) |
same as produtil.log.jlogger.info() More... | |
def | setstate (self, val) |
Sets the state of this job. More... | |
def | getstate (self) |
Returns the job state. More... | |
def | strstate (self) |
A string representation of the job state. More... | |
def | gettaskname (self) |
Returns the task name part of the database ID, which is the same as the prodname. More... | |
def | products (self, args, kwargs) |
Iterate over the products this task produces. More... | |
def | log (self) |
Returns the logger object for this task. More... | |
def | clean (self) |
Cleans up any unneeded data used by this task. More... | |
def | unrun (self) |
Undoes the effect of run(). More... | |
def | run (self) |
Performs the work this Task should do and generates all products. More... | |
def | is_completed (self) |
Is this task complete? More... | |
def | completed (self) |
Read-only property: is this task completed? Same as is_completed() More... | |
def | runpart (self) |
Run some of this task's work, deliver some products. More... | |
![]() | |
def | __init__ (self, dstore, prodname, category, meta=None, cache=30, location=None, kwargs) |
Datum constructor. More... | |
def | __enter__ (self) |
Acquires this object's thread lock. More... | |
def | __exit__ (self, etype, evalue, traceback) |
Releases this object's thread lock. More... | |
def | validate (self) |
Validates this object's Datastore, prodname and category. More... | |
def | getid (self) |
Returns the database ID of this datum. More... | |
def | getdatastore (self) |
Returns the datastore of this datum. More... | |
def | transaction (self) |
Creates, but does not lock, a Transaction for this datum's datastore. More... | |
def | getprodtype (self) |
Returns the product type of this Datum. More... | |
def | getprodname (self) |
Returns the product name part of the database ID. More... | |
def | getcategory (self) |
Returns the product category part of the database ID. More... | |
def | getlocation (self) |
Returns the "location" field of this Datum's database entry. More... | |
def | setlocation (self, v) |
Sets the "location" field of this Datum's database entry. More... | |
def | __hash__ (self) |
Integer hash function. More... | |
def | __str__ (self) |
Human-readable description of this Datum. More... | |
def | __repr__ (self) |
Python code-like description of this Datum. More... | |
def | __cmp__ (self, other) |
Compares two Datums' prodnames and categories. More... | |
def | set_loc_avail (self, loc, avail) |
Sets the location and availability of this Datum in a single transaction. More... | |
def | update (self) |
Discards all cached metadata and refreshes it from the Datastore. More... | |
def | __getitem__ (self, k) |
Returns the value of the specified metadata key or raises KeyError. More... | |
def | meta |
Return the value of a metadata key. More... | |
def | get |
Alias for self.meta() Returns the value of the specified metadata key or returns default if it is unset. More... | |
def | __setitem__ (self, k, v) |
Sets the value of the specified metadata key. More... | |
def | __delitem__ (self, k) |
Deletes the specified metadata key, which must not be "available" or "location". More... | |
def | __contains__ (self, k) |
Determines if a metadata key is set. More... | |
def | iteritems (self) |
Iterates over all metadata (key,value) pairs for this Datum, including "available" and "location". More... | |
Public Attributes | |
runwrf | |
The hwrf.fcsttask.WRFAtmos or subclass thereof that runs the WRF. More... | |
wrf | |
The hwrf.wrf.WRFSimulation describing the WRF simulation that was run. More... | |
postdoms | |
The array of WRF domains to post-process (hwrf.wrf.WRFDomain objects) | |
wrfdoms | |
The array of WRF domains (hwrf.wrf.WRFDomain objects) | |
moad | |
The Mother Of All Domains (MOAD) in the WRF simulation, an hwrf.wrf.WRFDomain object. More... | |
storm1inner | |
The innermost domain, an hwrf.wrf.WRFDomain. | |
storm1outer | |
The intermediate domain, an hwrf.wrf.WRFDomain. | |
nonsatpost | |
The non-satellite post-processor, an hwrf.post.PostManyWRF object. More... | |
satpost | |
The satellite post-processor, an hwrf.post.PostManyWRF object. More... | |
wrfcopier | |
The task that copies WRF input and output files directly to COM. More... | |
nhcp | |
The task that generates custom products for NHC. More... | |
track | |
The main track file from self.tracker. More... | |
tracker | |
Task that runs the GFDL vortex tracker on all three domains combined. More... | |
gribber | |
The hwrf.gribtask.GRIBTask that does the regribbing. More... | |
trackerd02 | |
The hwrf.tracker.TrackerTask that runs the GFDL vortex tracker on the combined outermost and intermediate domain vortex, omitting the innermost domain. More... | |
trackerd01 | |
The hwrf.tracker.TrackerTask that runs the GFDL vortex tracker on the outermost domain vortex only. More... | |
![]() | |
storminfo | |
The hwrf.storminfo.StormInfo describing the vitals information for the storm processed by this HWRFTask. More... | |
Additional Inherited Members | |
![]() | |
workdir | |
The directory in which this task should be run. More... | |
outdir | |
The directory in which this task should deliver its final output. More... | |
conf | |
This HWRFTask's hwrf.config.HWRFConfig object. More... | |
section | |
The confsection in self.section for this HWRFTask (read-only) More... | |
![]() | |
state | |
Read-write property: the job state. More... | |
taskname | |
Read-only property: the name of this task. More... | |
![]() | |
prodname = property(getprodname,None,None,) | |
Read-only property, an alias for getprodname(): the product name part of the database ID. More... | |
category = property(getcategory,None,None,) | |
Read-only property, an alias for getcategory(), the category name part of the database ID. More... | |
prodtype | |
Read-only property, an alias for getprodtype(), the product type. More... | |
did | |
Read-only property, an alias for getid(). More... | |
dstore | |
Read-only property, an alias for getdatastore(), the Datastore in which this Datum resides. More... | |
location | |
Read-write property, an alias for getlocation() and setlocation(). More... | |
def hwrf.hwrfsystem.HWRFForecastPostProcessing.__init__ | ( | self, | |
ds, | |||
conf, | |||
section, | |||
runwrf, | |||
wrf, | |||
postdoms, | |||
wrfdoms, | |||
moad, | |||
storm1inner, | |||
storm1outer, | |||
kwargs | |||
) |
Constructor for HWRFForecastPostProcessing.
ds | the produtil.datastore.Datastore to use |
conf | the HWRFConfig to use for configuration options. This conf is passed down to the RegribMany during regribbing operations. |
section | the config section to use. |
runwrf | the object that runs the forecast, such as an hwrf.fcsttask.WRFAtmos or hwrf.mpipomtc.WRFCoupledPOM |
wrf | the hwrf.wrf.WRFSimulation that represents the forecast model. |
postdoms | a list of domains to post-process in order of GRID id. |
wrfdoms | a list of WRF domains in order of GRID id |
moad | the Mother Of All Domains (MOAD), an hwrf.wrf.WRFDomain |
storm1inner | the first storm's intermediate domain, an hwrf.wrf.WRFDomain |
storm1outer | the first storm's innermost domain, an hwrf.wrf.WRFDomain |
kwargs | additional keyword arguments are passed to the superclass constructor |
Definition at line 363 of file hwrfsystem.py.
def hwrf.hwrfsystem.HWRFForecastPostProcessing.make_extra_trackers | ( | self | ) |
Generates intermediate and outermost domain trackers.
Generates trackers that use intermediate and outermost domain data to track the storm and analyze its intensity. These are intended for use in analyzing the effects of resolution and upscale feedback on hurricane track, structure and intensity. Creates these member variables and returns them:
Definition at line 748 of file hwrfsystem.py.
def hwrf.hwrfsystem.HWRFForecastPostProcessing.make_gribber_tracker | ( | self, | |
extra_trackers = False , |
|||
satpost_flag = True , |
|||
gofile_flag = False |
|||
) |
Generate the regribbing objects and the main tracker.
Generates the gribber, tracker, track and nhcp member variables and returns them in a tuple:
extra_trackers | logical flag: are the parent and intermediate domain trackers also desired? If so, extra regribbing is arranged, that will be required by make_extra_trackers() |
satpost_flag | logical flag: is satellite post-processing desired |
Definition at line 531 of file hwrfsystem.py.
def hwrf.hwrfsystem.HWRFForecastPostProcessing.make_nonsatpost | ( | self, | |
default_step = 1. |
|||
) |
Creates the non-satellite post-processor.
Creates the nonsatpost member, which runs the non-satellite post processing. That is the object that runs everything except the synthetic satellite brightness temperatures. This is a hwrf.post.PostManyWRF object.
default_step | non-satellite post-processor input step, if none is provided in the config file. |
Definition at line 417 of file hwrfsystem.py.
def hwrf.hwrfsystem.HWRFForecastPostProcessing.make_satpost | ( | self, | |
default_step = 6 |
|||
) |
Creates the satellite post-processor.
Creates the satpost member, an hwrf.post.PostManyWRF object that runs the satellite post-processing.
default_step | satellite post-processor input step, if none is provided in the config file. |
Definition at line 437 of file hwrfsystem.py.
def hwrf.hwrfsystem.HWRFForecastPostProcessing.make_wrfcopier | ( | self, | |
wrfcopier_name = 'copywrf' , |
|||
multistorm = False |
|||
) |
Generates the WRF input/output copier task.
Creates the wrfcopier member variable which copies inputs and outputs of the forecast job directly to COM. This is an hwrf.copywrf.WRFCopyTask object.
wrfcopier_name | the section and task name to use for the hwrf.copywrf.WRFCopyTask that is created. |
Definition at line 454 of file hwrfsystem.py.
hwrf.hwrfsystem.HWRFForecastPostProcessing.gribber |
The hwrf.gribtask.GRIBTask that does the regribbing.
Definition at line 731 of file hwrfsystem.py.
Referenced by hwrf.hwrfsystem.HWRFForecastPostProcessing.make_extra_trackers().
hwrf.hwrfsystem.HWRFForecastPostProcessing.moad |
The Mother Of All Domains (MOAD) in the WRF simulation, an hwrf.wrf.WRFDomain object.
Definition at line 391 of file hwrfsystem.py.
Referenced by hwrf.hwrfsystem.HWRFForecastPostProcessing.make_gribber_tracker().
hwrf.hwrfsystem.HWRFForecastPostProcessing.nhcp |
The task that generates custom products for NHC.
This is an hwrf.nhc_products.NHCProducts object.
Definition at line 728 of file hwrfsystem.py.
hwrf.hwrfsystem.HWRFForecastPostProcessing.nonsatpost |
The non-satellite post-processor, an hwrf.post.PostManyWRF object.
Definition at line 428 of file hwrfsystem.py.
Referenced by hwrf.hwrfsystem.HWRFForecastPostProcessing.make_gribber_tracker().
hwrf.hwrfsystem.HWRFForecastPostProcessing.runwrf |
The hwrf.fcsttask.WRFAtmos or subclass thereof that runs the WRF.
Definition at line 387 of file hwrfsystem.py.
Referenced by hwrf.hwrfsystem.HWRFForecastPostProcessing.make_gribber_tracker(), and hwrf.hwrfsystem.HWRFForecastPostProcessing.make_wrfcopier().
hwrf.hwrfsystem.HWRFForecastPostProcessing.satpost |
The satellite post-processor, an hwrf.post.PostManyWRF object.
Definition at line 447 of file hwrfsystem.py.
Referenced by hwrf.hwrfsystem.HWRFForecastPostProcessing.make_gribber_tracker().
hwrf.hwrfsystem.HWRFForecastPostProcessing.track |
The main track file from self.tracker.
Definition at line 729 of file hwrfsystem.py.
hwrf.hwrfsystem.HWRFForecastPostProcessing.tracker |
Task that runs the GFDL vortex tracker on all three domains combined.
This is an hwrf.tracker.TrackerTask.
Definition at line 730 of file hwrfsystem.py.
hwrf.hwrfsystem.HWRFForecastPostProcessing.trackerd01 |
The hwrf.tracker.TrackerTask that runs the GFDL vortex tracker on the outermost domain vortex only.
Definition at line 787 of file hwrfsystem.py.
hwrf.hwrfsystem.HWRFForecastPostProcessing.trackerd02 |
The hwrf.tracker.TrackerTask that runs the GFDL vortex tracker on the combined outermost and intermediate domain vortex, omitting the innermost domain.
Definition at line 786 of file hwrfsystem.py.
hwrf.hwrfsystem.HWRFForecastPostProcessing.wrf |
The hwrf.wrf.WRFSimulation describing the WRF simulation that was run.
Definition at line 388 of file hwrfsystem.py.
Referenced by hwrf.post.PostManyWRF.__init__(), hwrf.fcsttask.WRFAtmos.__init__(), hwrf.fcsttask.AnalysisCycle.anlintime(), hwrf.fcsttask.AnalysisCycle.anlouttime(), hwrf.fcsttask.WRFAnl.anltime(), hwrf.fcsttask.WRFAnl.deliver_products(), hwrf.fcsttask.AnalysisCycle.deliver_products(), hwrf.fcsttask.RealNMM.fort65_at_time(), hwrf.multistorm.WRFAtmosMultiStorm.make_namelist(), hwrf.fcsttask.WRFTaskBase.make_namelist(), hwrf.fcsttask.RealNMM.make_namelist(), hwrf.fcsttask.WRFAnl.make_products(), hwrf.fcsttask.AnalysisCycle.make_products(), hwrf.hwrfsystem.HWRFForecastPostProcessing.make_wrfcopier(), hwrf.post.PostManyWRF.products(), hwrf.fcsttask.WRFAnl.products(), hwrf.fcsttask.WRFAnl4Trak.products(), hwrf.fcsttask.AnalysisCycle.products(), hwrf.fcsttask.WRFAnl4Trak.retime_wrfout(), hwrf.post.PostManyWRF.taskname_for(), hwrf.fcsttask.WRFAnl.wrfanl_at_time(), hwrf.fcsttask.RealNMM.wrfbdy_at_time(), hwrf.fcsttask.RealNMM.wrfinput_at_time(), and hwrf.fcsttask.AnalysisCycle.wrfinput_at_time().
hwrf.hwrfsystem.HWRFForecastPostProcessing.wrfcopier |
The task that copies WRF input and output files directly to COM.
This is an hwrf.copywrf.WRFCopyTask object.
Definition at line 524 of file hwrfsystem.py.