tke_test.py 1.68 KB
Newer Older
mashun1's avatar
veros  
mashun1 committed
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
import pytest

from veros.core import tke
from veros.pyom_compat import get_random_state

from test_base import compare_state

TEST_SETTINGS = dict(
    nx=70,
    ny=60,
    nz=50,
    dt_tracer=3600,
    dt_mom=3600,
    enable_cyclic_x=True,
    enable_idemix=True,
    tke_mxl_choice=2,
    enable_tke=True,
    enable_eke=True,
    enable_store_cabbeling_heat=True,
    enable_store_bottom_friction_tke=False,
    enable_tke_hor_diffusion=True,
    enable_tke_superbee_advection=True,
    enable_tke_upwind_advection=True,
)

PROBLEM_SETS_SET_DIFF = {
    "tke": dict(enable_tke=True),
    "no-tke": dict(enable_tke=False),
}

PROBLEM_SETS_INTEGRATE = {
    "eke+idemix": dict(enable_eke=True, enable_idemix=True),
    "no-eke+idemix": dict(enable_eke=False, enable_idemix=True),
    "eke+no-idemix": dict(enable_eke=True, enable_idemix=False),
    "no-eke+no-idemix": dict(enable_eke=False, enable_idemix=False),
}


@pytest.mark.parametrize("problem_set", PROBLEM_SETS_SET_DIFF)
def test_set_tke_diffusivities(pyom2_lib, problem_set):
    settings = {**TEST_SETTINGS, **PROBLEM_SETS_SET_DIFF[problem_set]}
    vs_state, pyom_obj = get_random_state(pyom2_lib, extra_settings=settings)

    vs_state.variables.update(tke.set_tke_diffusivities(vs_state))
    pyom_obj.set_tke_diffusivities()
    compare_state(vs_state, pyom_obj)


@pytest.mark.parametrize("problem_set", PROBLEM_SETS_INTEGRATE)
def test_integrate_tke(pyom2_lib, problem_set):
    settings = {**TEST_SETTINGS, **PROBLEM_SETS_INTEGRATE[problem_set]}
    vs_state, pyom_obj = get_random_state(pyom2_lib, extra_settings=settings)

    vs_state.variables.update(tke.integrate_tke(vs_state))
    pyom_obj.integrate_tke()
    compare_state(vs_state, pyom_obj)