https://github.com/GPflow/GPflow
Revision fb66fb55522baf017ceb4d710d035d9df153d41a authored by Artem Artemev on 07 January 2020, 21:12:15 UTC, committed by st-- on 07 January 2020, 21:12:15 UTC
Closes #1191
1 parent ec54849
Tip revision: fb66fb55522baf017ceb4d710d035d9df153d41a authored by Artem Artemev on 07 January 2020, 21:12:15 UTC
Improve Parameter.assign docstring (#1193)
Improve Parameter.assign docstring (#1193)
Tip revision: fb66fb5
test_utilities.py
import numpy as np
import pytest
import tensorflow_probability as tfp
from gpflow.config import Config, as_context
from gpflow.utilities import positive, triangular
@pytest.mark.parametrize("env_lower, override_lower", [
(0.1, None), # ensure default from config is applied
(None, 0.2), # ensure override is applied
(0.3, 0.4), # ensure local overrides config
])
def test_positive_lower(env_lower, override_lower):
expected_lower = override_lower or env_lower
with as_context(Config(positive_bijector="softplus", positive_minimum=env_lower)):
bijector = positive(lower=override_lower)
assert isinstance(bijector, tfp.bijectors.Chain)
assert np.isclose(bijector.bijectors[0].shift, expected_lower)
@pytest.mark.parametrize("env_bijector, override_bijector, expected_class", [
("softplus", None, tfp.bijectors.Softplus),
("softplus", "Exp", tfp.bijectors.Exp),
("exp", None, tfp.bijectors.Exp),
("exp", "Softplus", tfp.bijectors.Softplus),
])
def test_positive_bijector(env_bijector, override_bijector, expected_class):
with as_context(Config(positive_bijector=env_bijector, positive_minimum=None)):
bijector = positive(base=override_bijector)
assert isinstance(bijector, expected_class)
def test_positive_calculation_order():
value, lower = -10.0, 10.0
expected = np.exp(value) + lower
with as_context(Config(positive_bijector="exp", positive_minimum=lower)):
result = positive()(value).numpy()
assert np.isclose(result, expected)
assert result >= lower
def test_triangular():
assert isinstance(triangular(), tfp.bijectors.FillTriangular)
Computing file changes ...