79 lines
2.6 KiB
Python
79 lines
2.6 KiB
Python
|
#!/usr/bin/python
|
||
|
|
||
|
import unittest
|
||
|
|
||
|
import math
|
||
|
|
||
|
from baker import run_baker
|
||
|
|
||
|
from grid.DD import grid
|
||
|
from grid.simplex import contains
|
||
|
|
||
|
def exact_func(X):
|
||
|
x = X[0]
|
||
|
y = X[0]
|
||
|
return 1 - math.sin((x-0.5)**2 + (y-0.5)**2)
|
||
|
|
||
|
class TestSequenceFunctions(unittest.TestCase):
|
||
|
def setUp(self):
|
||
|
self.points = [
|
||
|
[ 0.25, 0.40], # 0
|
||
|
[ 0.60, 0.80], # 1
|
||
|
[ 0.65, 0.28], # 2
|
||
|
[ 0.28, 0.65], # 3
|
||
|
[ 1.00, 0.75], # 4
|
||
|
[ 0.30, 0.95], # 5
|
||
|
[ 0.80, 0.50], # 6
|
||
|
[ 0.35, 0.15], # 7
|
||
|
]
|
||
|
self.q = [exact_func(p) for p in self.points]
|
||
|
|
||
|
self.X = [0.55, 0.45]
|
||
|
|
||
|
self.g = grid(self.points, self.q)
|
||
|
self.g.construct_connectivity()
|
||
|
self.R = self.g.create_mesh(range(3))
|
||
|
|
||
|
self.exact = exact_func(self.X)
|
||
|
|
||
|
|
||
|
self.accuracy = 8
|
||
|
|
||
|
def test_R_contains_X(self):
|
||
|
self.assertTrue(contains(self.X, self.R.points))
|
||
|
|
||
|
def test_RunBaker_1_extra_point(self, extra=1):
|
||
|
S = self.g.create_mesh(range(3, 3 + extra))
|
||
|
answer = run_baker(self.X, self.R, S, order=3)
|
||
|
lin_err = abs(self.exact - answer['qlin'])
|
||
|
final_err = abs(self.exact - answer['final'])
|
||
|
self.assertTrue(lin_err >= final_err)
|
||
|
def test_RunBaker_2_extra_point(self, extra=2):
|
||
|
S = self.g.create_mesh(range(3, 3 + extra))
|
||
|
answer = run_baker(self.X, self.R, S, order=3)
|
||
|
lin_err = abs(self.exact - answer['qlin'])
|
||
|
final_err = abs(self.exact - answer['final'])
|
||
|
self.assertTrue(lin_err >= final_err)
|
||
|
def test_RunBaker_3_extra_point(self, extra=3):
|
||
|
S = self.g.create_mesh(range(3, 3 + extra))
|
||
|
answer = run_baker(self.X, self.R, S, order=3)
|
||
|
lin_err = abs(self.exact - answer['qlin'])
|
||
|
final_err = abs(self.exact - answer['final'])
|
||
|
self.assertTrue(lin_err >= final_err)
|
||
|
def test_RunBaker_4_extra_point(self, extra=4):
|
||
|
S = self.g.create_mesh(range(3, 3 + extra))
|
||
|
answer = run_baker(self.X, self.R, S, order=3)
|
||
|
lin_err = abs(self.exact - answer['qlin'])
|
||
|
final_err = abs(self.exact - answer['final'])
|
||
|
self.assertTrue(lin_err >= final_err)
|
||
|
def test_RunBaker_5_extra_point(self, extra=5):
|
||
|
S = self.g.create_mesh(range(3, 3 + extra))
|
||
|
answer = run_baker(self.X, self.R, S, order=3)
|
||
|
lin_err = abs(self.exact - answer['qlin'])
|
||
|
final_err = abs(self.exact - answer['final'])
|
||
|
self.assertTrue(lin_err >= final_err)
|
||
|
|
||
|
if __name__ == '__main__':
|
||
|
suite = unittest.TestLoader().loadTestsFromTestCase(TestSequenceFunctions)
|
||
|
unittest.TextTestRunner(verbosity=3).run(suite)
|