diff --git a/doc/quick_surge.rst b/doc/quick_surge.rst index 0bb2136..d364d31 100644 --- a/doc/quick_surge.rst +++ b/doc/quick_surge.rst @@ -29,27 +29,69 @@ for a new example usually involves two data source can also be found in :ref:`surgedata` and a description of how to include them in :ref:`_surge_module`. -.. warning:: This is a work in progress and only partially has been filled out. - If you are interested in the rest of the steps or wish to contribute your - own workflow please let us know! +Here we will concentrate on changing the Hurricane Ike (2018) example into one for +Hurricane Elsa (2021). -Here we will concentrate on changing the Hurricane Ike example into one for -Hurricane Katrina. +1. First copy the files (setrun.py, setplot.py, makefile) located in the Hurricane Ike directorty located at + `$CLAW/geoclaw/examples/storm-surge/ike`. Note: if reader has not yet set up environment + variable `CLAW`, please refer to this page: `Setting Environment Variable `__. -1. First copy the files located in the Hurricane Ike directorty located at - `$CLAW/geoclaw/examples/storm-surge/ike`. +2. Next let’s find some better topography for the west coast Florida area. There are several places where we can get topography/bathymetry data, for + example `Global Multi-Resolution Topography Data Synthesis `__, + `Global Digital Elevation Model `__, + `National Center for Environmental Information `__, + and `The General Bathymetry Chart of the Oceans `__. + Here we will use the data from the last one which is the GEBCO to retrive and download the topography and bathymetry data for hurricane Elsa. Theoretically, we + can select the region as big as possible. However, the bigger the region, the more time it will take for GeoClaw simulation to run. So for hurricane Elsa, + we only use the gulf of Mexico region so that it can include the region days before Elsa's landfall and the region days after the landfall. (How to specify how many + days before and after will be discussed in later steps below.) After downloading the grid format of the topography data, we may want to store it on cloud like google drive, + dropbox, or your personal website so that people in the future can have access to this topography data file. -2. Next let's find some better topography for the New Orleans area... +3. Now let’s find a storm specification for Hurricane Elsa. Several data resouces are available: `Automated Tropical Cyclone Forecasting System `__, + `Atlantic Oceanographic and Meteorological Laboratory `__, + `NOAA Rapid Update Cycle `__, + `National Center for Environmental Information `__, + `Naval Meteorology and Oceanography Command `__, + `Coastal Hazards System `__. + In this example we will use the ATCF database. For Hurricane Elsa, this ends up being + the file located `here `__. + How to find a storm specific data using ATCF database for your storm? Go to `ATCF Archive `__. Then + search for you storm number. In this example, storm number for Hurricane Elsa is `AL052021`. Therefore, the storm data corresponds to Hurricane Elsa will simply + be `bal052021.dat` in year 2021. -3. Now let's find a storm specification for Hurricane Katrina. In this - example we will use the ATCF database. For Katrina this ends up being - the file located `here <>`_. +4. Now we have our topography data and storm specific data ready. Next, we need to modify the `setrun.py` to use + our new storm specific data and topography data we just added. First, modify the + computational domain so that it matches or is contained in the region of the topography data. + Then change :code:`t0`, :code:`tfinal`, and :code:`time_offset` + to Elsa's landfall time and time period before and after landfall we want to simulate. + Last but not least, change locations of retrieving topography and storm data file in topography data and + surge data sections. -4. We now need to modify the `setrun.py` to use our new storm format and - topography we now added... +5. We also need to modify the plotting in `setplot.py`. + First, we may want to change upper and lower limits for surface levels, wind speeds, + pressure, and friction to best represent our storm. For example, Elsa is a category 1 hurricane which is + not very strong. Therefore, we changed the surface levels to :code:`[-1, 1]` so that + visualization from plots will be more evident. In the plot specifications section, we can add + zoom-in regions. For Elsa, three more regions other than the computational domain are added. We may + also alter the legends, labels, colors of plots, and so on. -5. Finally we need to also modify the plotting so that we have an +6. Gauges are key for validation study. We want to know how good GeoClaw's simulation is + comparing to observed currents and tides data. Gauge information and location + can be found here at `NOAA Tides & Currents `__. + In `setrun.py`, add gauge locations using the :code:`rundata.gaugedata.gauges.append()` method. + Accordingly in `setplot.py`, modify parameters of the :code:`geoclaw.util.fetch_noaa_tide_data()` method + so that observed data from gauges will be fetched and plotted along with simulation. -6. Gauges... +7. Sometimes, plots will not look correct even though we inputed the exactly precise locations of gauges. One highly possible reason for that + is our region is not resolved enough. Consequently, GeoClaw might recognize topography of locations wrongly. To solve this problem, we will + use the `AMRClaw `__ algorithm to further + refine regions. For this example, Tampa Bay area was not recognized by GeoClaw until 6 levels of refinement was implemented. -7. Running the simulation... +8. Finally we are ready to run the simulation. Make sure all files (setrun.py, setplot.py, makefile) are in the correct directory, + then :code:`$ cd DirectoryPath` to the working directory. In that working directory, we can either use :code:`$ make all` or :code:`$ make .plots` + to execute. If errors are encountered, we can follow the sequence of :code:`$ make .exe`, :code:`$ make .data`, :code:`$ make .output`, and + :code:`$ make .plots` to debug. To eliminate all executable files and restart, we can use :code:`$ make clean`. + Once the simulation runs successfully, we can see the result at :code:`DirectoryPath/_plots/_PlotIndex.html`. + +For a more detailed, step-by-step guide to storm surge simulations/validations, please find the jupyter +notebook `setup.ipynb` at this `github repository `__.