(in directory: verification/tutorial_plume_on_slope/
)
Temperature after 23 hours of cooling. The cold dense water is mixed with ambient water as it accelerates down the slope and hence is warmer than the unmixed plume.
An important test of any ocean model is the ability to represent the flow of dense fluid down a slope. One example of such a flow is a non-rotating gravity plume on a continental slope, forced by a limited area of surface cooling above a continental shelf. Because the flow is non-rotating, a two dimensional model can be used in the across slope direction. The experiment is non-hydrostatic and uses open-boundaries to radiate transients at the deep water end. (Dense flow down a slope can also be forced by a dense inflow prescribed on the continental shelf; this configuration is being implemented by the DOME (Dynamics of Overflow Mixing and Entrainment) collaboration to compare solutions in different models).
The fluid is initially unstratified. The surface buoyancy loss B0 (dimensions of L2T − 3) over a cross-shelf distance R causes vertical convective mixing and modifies the density of the fluid by an amount
where H is the depth of the shelf, g is the acceleration due to gravity, t is time since onset of cooling and ρ0 is the reference density. Dense fluid slumps under gravity, with a flow speed close to the gravity wave speed:
A steady state is rapidly established in which the buoyancy flux out of the cooling region is balanced by the surface buoyancy loss. Then
The Froude number of the flow on the shelf is close to unity (but in practice slightly less than unity, giving subcritical flow). When the flow reaches the slope, it accelerates, so that it may become supercritical (provided the slope angle α is steep enough). In this case, a hydraulic control is established at the shelf break. On the slope, where the Froude number is greater than one, and gradient Richardson number (defined as Ri ∼ g′h*/U2 where h* is the thickness of the interface between dense and ambient fluid) is reduced below 1/4, Kelvin-Helmholtz instability is possible, and leads to entrainment of ambient fluid into the plume, modifying the density, and hence the acceleration down the slope. Kelvin-Helmholtz instability is suppressed at low Reynolds and Peclet numbers given by
where h is the depth of the dense fluid on the slope. Hence this experiment is carried out in the high Re, Pe regime. A further constraint is that the convective heat flux must be much greater than the diffusive heat flux (Nusselt number ≫ 1). Then
Finally, since we have assumed that the convective mixing on the shelf occurs in a much shorter time than the horizontal equilibration, this implies H/R ≪ 1.
Hence to summarize the important non-dimensional parameters, and the limits we are considering:
In addition we are assuming that the slope is steep enough to provide sufficient acceleration to the gravity plume, but nonetheless much less that 1:1, since many Kelvin-Helmholtz billows appear on the slope, implying horizontal length scale of the slope ≫ the depth of the dense fluid.
The topography, spatial grid, forcing and initial conditions are all specified in binary data files generated using matlab script verification/tutorial_plume_on_slope/input/gendata.m
and detailed in tut_plume_on_slope_config
. Other model parameters are specified in input/data <verification/tutorial_plume_on_slope/input/data>
and input/data.obcs <verification/tutorial_plume_on_slope/input/data.obcs>
and detailed in tut_plume_on_slope_mod_parms
.
Horizontal grid spacing, Δx, in the across-slope direction for the gravity plume experiment.
Topography, h(x), used for the gravity plume experiment.
Upward surface heat flux, Q(x), used as forcing in the gravity plume experiment.
The domain is 200 m deep and 6.4 km across. Uniform resolution of 60 × 31/3 m is used in the vertical and variable resolution of the form shown in dx-plume-on-slope
with 320 points is used in the horizontal. The formula for Δx is:
where
Here, Δx1 is the resolution on the shelf, Δx2 is the resolution in deep water and Nx is the number of points in the horizontal.
The topography, shown in depth-plume-on-slope
, is given by:
where
Here, s is the maximum slope, Ho is the maximum depth, hs is the shelf depth, xs is the lateral position of the shelf-break and Ls is the length-scale of the slope.
The forcing is through heat loss over the shelf, shown in Q-plume-on-slope
and takes the form of a fixed flux with profile:
where
Here, Qo is the maximum heat flux, xq is the position of the cut-off, and Lq is the width of the cut-off.
The initial temperature field is unstratified but with random perturbations, to induce convection early on in the run. The random perturbation are calculated in computational space and because of the variable resolution introduce some spatial correlations, but this does not matter for this experiment. The perturbations have range 0 − 0.01 ∘K.
The computational domain (number of gridpoints) is specified in code/SIZE.h <verification/tutorial_plume_on_slope/code/SIZE.h>
and is configured as a single tile of dimensions 320 × 1 × 60.
To compile the model code for this experiment, the non-hydrostatic algorithm needs to be enabled, and the open-boundaries package (pkg/obcs
) is required:
- Non-hydrostatic terms and algorithm are enabled with
#define
ALLOW_NONHYDROSTATIC
incode/CPP_OPTIONS.h <verification/tutorial_plume_on_slope/code/CPP_OPTIONS.h>
and activated withnonHydrostatic
=.TRUE,
in namelistPARM01
ofinput/data <verification/tutorial_plume_on_slope/input/data>
. - Open boundaries are enabled by adding line
obcs
to package configuration filecode/packages.conf <verification/tutorial_plume_on_slope/code/packages.conf>
and activated viauseOBCS
=.TRUE,
in namelistPACKAGES
ofinput/data.pkg <verification/tutorial_plume_on_slope/input/data.pkg>
.
Parameter | Value | Description |
---|---|---|
g | 9.81 m s-2 | acceleration due to gravity |
ρo | 999.8 kg m-3 | reference density |
|
2 × 10-4 K-1 | expansion coefficient |
Ah | 1 × 10-2 m2 s-1 | horizontal viscosity |
Av | 1 × 10-3 m2 s-1 | vertical viscosity |
κh | 0 m2 s-1 | (explicit) horizontal diffusion |
κv | 0 m2 s-1 | (explicit) vertical diffusion |
Δt | 20 s | time step |
Δz | 3.33333 m | vertical grid spacing |
Δx |
|
horizontal grid spacing |
The model parameters (tut_plume_parm_table
) are specified in input/data <verification/tutorial_plume_on_slope/input/data>
and if not assume the default values as defined in customize_model
. A linear equation of state is used, eosType
=’LINEAR’
, but only temperature is active, sBeta
=0.E-11
. For the given heat flux, Qo, the buoyancy forcing is