Revision e9275c2749d590998082da0544957d33c28d59e5 authored by Mark van der Wilk on 03 May 2017, 17:08:06 UTC, committed by GitHub on 03 May 2017, 17:08:06 UTC
* Add regression test for NaNs in gradient * Fix NaN in gradient if cos_theta is close to one * Use jitter close to machine epsilon
1 parent 5190ada
test_config.py
import unittest
import GPflow
import os
import tensorflow as tf
class TestConfigParsing(unittest.TestCase):
def setUp(self):
directory = os.path.dirname(os.path.realpath(__file__))
f = os.path.join(directory, 'gpflowrc_test.txt')
self.conf = GPflow._settings.read_config_file(f)
self.settings = GPflow._settings.namedtuplify(self.conf._sections)
def test(self):
self.assertTrue(all([
self.settings.first_section.a_bool is False,
self.settings.first_section.a_float == 1e-3,
self.settings.first_section.a_string == 'hello',
self.settings.first_section.a_type is tf.float64,
self.settings.second_section.a_bool is True,
self.settings.second_section.another_bool is True,
self.settings.second_section.yet_another_bool is False]))
def test_parser(self):
with self.assertRaises(ValueError):
GPflow._settings.parse(None)
with self.assertRaises(ValueError):
GPflow._settings.parse(12)
with self.assertRaises(ValueError):
GPflow._settings.parse([])
self.assertTrue(GPflow._settings.parse('false') is False)
self.assertTrue(GPflow._settings.parse('False') is False)
self.assertTrue(GPflow._settings.parse('true') is True)
self.assertTrue(GPflow._settings.parse('True') is True)
self.assertTrue(GPflow._settings.parse('int32') is tf.int32)
self.assertTrue(GPflow._settings.parse('32') is 32)
self.assertTrue(GPflow._settings.parse('32.') == 32.)
self.assertTrue(GPflow._settings.parse('int') == 'int')
self.assertTrue(GPflow._settings.parse('hello') == 'hello')
self.assertTrue(GPflow._settings.parse('1E2') == 1e2)
self.assertTrue(GPflow._settings.parse('1e-9') == 1e-9)
class TestSettingsManager(unittest.TestCase):
def testRaises(self):
with self.assertRaises(AttributeError):
GPflow.settings.undefined_setting_to_raise_error
def testMutability(self):
orig = GPflow.settings.verbosity.hmc_verb
GPflow.settings.verbosity.hmc_verb = False
self.assertTrue(GPflow.settings.verbosity.hmc_verb is False)
GPflow.settings.verbosity.hmc_verb = True
self.assertTrue(GPflow.settings.verbosity.hmc_verb is True)
GPflow.settings.verbosity.hmc_verb = orig
def testContextManager(self):
orig = GPflow.settings.verbosity.hmc_verb
GPflow.settings.verbosity.hmc_verb = True
config = GPflow.settings.get_settings()
config.verbosity.hmc_verb = False
self.assertTrue(GPflow.settings.verbosity.hmc_verb is True)
with GPflow.settings.temp_settings(config):
self.assertTrue(GPflow.settings.verbosity.hmc_verb is False)
self.assertTrue(GPflow.settings.verbosity.hmc_verb is True)
GPflow.settings.verbosity.hmc_verb = orig
if __name__ == "__main__":
unittest.main()
Computing file changes ...