-
Notifications
You must be signed in to change notification settings - Fork 10
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #20 from wrightky/master
Add nourishment functions
- Loading branch information
Showing
11 changed files
with
586 additions
and
26 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,69 @@ | ||
.. _example14: | ||
|
||
Example 14 - Nourishment Area and Time Functions | ||
================================================ | ||
|
||
In this example, we analyze the travel history of a particle injection by computing the "nourishment area" and "nourishment time" for a given seed location. | ||
|
||
Full example script available :download:`here <../../../examples/nourishment_example.py>`. | ||
|
||
We will again make use of the DeltaRCM example data used in :ref:`example02`, but in this case we will slightly change the settings used in the random walk. In particular, this time we will include discharge fields, in order to obtain more useful travel time information. | ||
|
||
.. doctest:: | ||
|
||
>>> import numpy as np | ||
>>> import dorado | ||
>>> data = np.load('ex_deltarcm_data.npz') | ||
|
||
Now we will create the parameter class and assign attributes to it. | ||
|
||
.. doctest:: | ||
|
||
>>> params = dorado.particle_track.modelParams() | ||
>>> params.stage = data['stage'] | ||
>>> params.depth = data['depth'] | ||
>>> params.qx = data['qx'] | ||
>>> params.qy = data['qy'] | ||
>>> params.dx = 50. | ||
>>> params.gamma = 0.5 | ||
>>> params.model = 'DeltaRCM' | ||
|
||
Now that the parameters have all been defined, we will define the particles class and generate a set of particles. | ||
|
||
.. doctest:: | ||
|
||
>>> seed_xloc = list(range(15, 17)) | ||
>>> seed_yloc = list(range(137, 140)) | ||
>>> Np_tracer = 300 | ||
>>> particles = dorado.particle_track.Particles(params) | ||
>>> particles.generate_particles(Np_tracer, seed_xloc, seed_yloc) | ||
|
||
Now, we will route the particles for 120 iterations. Notice that we have used more particles and iterations than in :ref:`example02` -- this helps us obtain more statistically representative results later on. | ||
|
||
.. doctest:: | ||
|
||
>>> walk_data = dorado.routines.steady_plots(particles, 120, 'nourishment_example') | ||
|
||
Now that we have an existing `walk_data` dictionary, let's visualize some bulk information about the travel history. First, we can compute which regions of the domain were most visited by particles. This metric is often referred to as the `Nourishment Area` (e.g. Liang et al., 2016, doi.org/10.1002/2015JF003653) of a sample location, as it represents regions which are "nourished" by material from that location. We can compute how frequently cells were visited by particles using the `nourishment_area` function, and visualize the results using the `show_nourishment_area` routine. | ||
|
||
.. doctest:: | ||
|
||
>>> visit_freq = dorado.particle_track.nourishment_area(walk_data, params.depth.shape) | ||
>>> ax = dorado.routines.show_nourishment_area(visit_freq, params.depth, walk_data) | ||
|
||
.. image:: images/example14/NourishmentArea.png | ||
|
||
The result is visualized in the figure above. Flow depth serves as the background in this figure, on top of which the Nourishment Area is shown, with regions colored by how frequently each cell was occupied by particles. Because we are often interested in where particles can go in general, rather than exactly where they have gone, by default this function will perform a small amount of Gaussian filtering, to smooth out some of the stochasticity in the travel paths. This smoothing can be turned off or ramped up depending on the application. Additionally, the plotting routine comes with many optional settings which can be used to change the aesthetics of the resulting figure. | ||
|
||
Because the Nourishment Area is a time-integrated measure of where particles are going, we may also want to know how long particles tend to stay there once they get there. For this question, we have provided a second function, which we are calling the Nourishment Time, which computes how long on average particles spend in each cell they travel through. In steady model runs (such as this one), the result is trivially related to the flow velocity of each cell -- however, for unsteady runs, in which the underlying flow field might be changing in between particle iterations, the results of this function can be more interesting. | ||
|
||
Similar to before, we compute this by calling on the `nourishment_time` function, and visualize the results using the `show_nourishment_time` routine. | ||
|
||
.. doctest:: | ||
|
||
>>> mean_times = dorado.particle_track.nourishment_time(walk_data, params.depth.shape, clip=95) | ||
>>> ax = dorado.routines.show_nourishment_time(mean_times, params.depth, walk_data) | ||
|
||
.. image:: images/example14/NourishmentTime.png | ||
|
||
The result is visualized above. As with the previous function, some amount of spatial filtering has been applied. From comparing these two figures, some interesting trends emerge. For example, even though the main distributary channels are frequently visited by particles, the particles on average don't spend very much time there. Depending on the material or question of interest, perhaps these can provide useful insights! |
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,4 +1,5 @@ | ||
__version__ = "2.3.0" | ||
__version__ = "2.4.0" | ||
|
||
|
||
from . import lagrangian_walker | ||
from . import parallel_routing | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.